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1.0 INTRODUCTION 



The Adaptec ACB-35 30 streaming tape controller board interfaces a 
1/4" streaming tape drive using the QIC-36 interface to any host 
interface compatible with the ANSI X3T9.2 Small Computer System 
Interface (SCSI) . 



ACP-35 3P FEATURE .SET 



0 FULL SCSI SPECIFICATION, REVISION 14B f COMPATIBILITY. 
Connects to any SCSI standard host adapter. 

0 SCSI BUS ARBITRATION AND DISCONNECT/ RECONNECT SUPPORT. 

Overlapped disk/tape operation capability with multitasking 
I/O subsystems. 

0 BUFFERED WRITE AND IMMEDIATE COMMAND COMPLETION SUPPORT. 

Data buffering and immediate completion mode for streaming 
on systems that do not support SCSI bus disconnect/ 
reconnect. 

0 QIC-24 AND QIC-11 MEDIA FORMAT SUPPORT. 

Capable of reading and writing QIC-24 and QIC-11 format 
tapes. 

0 16 BIT CRC ON EACH RECORD AND SCSI BUS PARITY. 

Data integrity is assured by reading the data and checking 
CRC immediatly after it is written. CRC is also checked on 
tape reads. In addition, SCSI bus parity is checked or 
generated on all bus transfers. 

0 AUTOMATIC TAPE DEFECT HANDLING. 

Media defects detected by the controller from read after 
write will result in the data being rewritten in the next 
sequential block. 

0 RESERVE/RELEASE. 

The tape drive can be reserved by an attached host to 
restrict other host accesses to the data. 



ACB-35 30 Users Manual 



1-1 



400112-00A 



1^2. REFERENCE DOCUMENTS 

o ANSI X3T9.2, Small Computer System Interface Specification, 
Revision 14B 

o QIC-24 Specification: Proposed standard for data interchange 
on streaming 1/4" drives. 

o QIC-11 Specification: Proposed standard for data interchange 
on streaming 1/4" drives. 

o QIC-36 Specification: 1/4" Streaming tape drive basic 
interface. 



l^i ACP-35 3Q CONTROLLER LAYOUT 



The dimensions and component layout of the ACB-3530 is shown in 
Figure 1-1. This diagram is referred to later in the manual for 
the location of the interface connectors, bus terminators and 
configuration jumpers. 

The outside board dimensions and mounting holes are designed to 
fit into the standard QIC-02 controller envelope. These 
dimensions are slightly narrower than the holes provided on most 
drives for mounting to a system chassis. Additional hardware (not 
provided) is required to use these mounting holes for the 
controller. 
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Figure 1-1.. ACB-35 30 Board Layout 
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JLA PR OP PCT SPECIFICATION 



The ACB-3530 controller is designed to function under normal 
operating conditions for electronic components. The form factor 
is such that the controller can be mounted with the drive inmost 
systems. 



1.4..1 PHYSI C AL DIMENSIONS 



Length 

Width 

Height 



8.75 inches (19.7 cm) 
5.5 0 inches (14.6 cm) 
.75 inches ( 1.9 cm) 



1^.2. PQWER REQUIREMENTS 



+5 VDC ± 5% at 1.8 Amps (max) 
+12 VDC ± 10% at 100 mAmp (max) 



1.5-^.2 ENVIRONM EN TAL REQUIREMENTS 



Temperature (P/C) 
Humidity (non-cond) 
Altitude (feet) 



Operating 



32/0 
10 % 
Sea L. 



to 131/55 
to 95 % 
to 10,000 



Storage 

-4 0/-40 to 167/75 
10 % to 95 % 
Sea L. to 20,000 



Exhaust air flow may be required to keep the air on both sides of 
the board at or below the maximum operating temperature. 
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2.0 THEORY OF OPERATION 



The ACB-3530 architecture is designed around the Adaptec 
controller chips; the AIC-010 and AIC-300. This architecture 
divides the controller into two basic components, a data path and 
a control path. A block diagram of the ACB-35 30 is shown in 
Figure 2-1. 



2*1 ACP-3530 AKCHITFCTPfiE 

The ACB-3530 data path carries data to and from the attached QIC- 
36 tape drive and host. Data is transferred in an asynchronous 
fashion from the host to/from the controller 8K dual ported 
buffer RAM. The buffer dual port addressing and port handshaking 
is controlled by the AIC-300. Odd bus parity is checked on data 
transferred into the buffer and generated on data transferred 
onto the SCSI bus. The dual ported buffer is designed to allow 
data to be written into one port (ie. from the host) as it is 
being read out from the other (ie. to the tape) in a FIFO 
fashion. 

Data is transferred between the RAM buffer and the AIC-010 
sequencer using synchronous timing to assure streaming operation. 
Data is converted into a serial NRZ data stream in the QIC-24 
format by the AIC-010. The QIC-24 ID and data fields are then 
appended with CRC information. This NRZ data stream is encoded 
into the GCR encoding scheme and written onto the tape. As data 
is being written, the ACB-35 30 is also performing a CRC check on 
the data and will rewrite blocks if any errors are detected. 

An 8 bit microprocessor is used to initialize and monitor the 
status of the data path and serves as the main component of the 
control path. The microprocessor drives the SCSI control lines to 
sequence through the various bus phases and decodes all SCSI 
commands. The micro is further used in the SCSI interface to 
report all errors encountered and to transfer messages to the 
host. 

The microprocessor also performs the main controlling functions 
on the QIC-36 interface. These include track select, motion 
control and cartridge status (in or out). 
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Figure 2-1. ACB-35 30 Block Diagram 
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ZmI MICRQCOPP STRUCTURE 



The controlling microcode for the ACB-3530 is preprogrammed in 
16K of (Ep)ROM memory. This firmware contains all routines 
necessary to properly interface to the SCSI bus and the QIC-36 
interface and to control the tape data path. Figure 2-2 contains 
a basic flow chart for the controller firmware. 
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Figure 2-2. ACB-3530 Controlling Firmware. 
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3.0 INSTALLATION OF THE ACB-35 30 



The ACB-3530 is designed to provide the performance and 
flexibility required to reliably operate a QIC-36 1/4" tape 
drive for streaming backup of system data. Some basic 
installation steps are required to assure proper board operation. 



2lJl UN PACKING 

The ACB-3530 is shipped in a protective carton with shock 
absorbing and static protection material completely surrounding 
the card. The carton should be examined for external damage as it 
is opened. The cards are physically inspected prior to packaging, 
any damage noted should be reported immediately. 

CAUTION- All circuit boards containing VLSI circuitry have some 
sensitivity to electro-static discharge. The ACB-3530 is no 
exception. Proper handling precautions, including personnel 
and work surface grounding, should be taken to prevent circuit 
stress which can cause component failure. 



2*2 PERPARATIQN £E INSTALLATION AREA 

The ACB-35 30 is generally designed into the physical host system 
or a peripheral subsystem. Proper attention should be given to 
the location of the ACB-3530 to assure the necessary ventilation, 
installation clearances and cabling paths are provided. 



l^Z^L MOUNTING CONSIDERATIONS 

The ACB-35 30 can be physically mounted using the 4 mounting 
holes. These holes are in locations compatible with standard QIC- 
02 controllers for mounting onto the drive. The controller can 
also be mounted onto custom designed brackets for alternate 
mechanical requirements. Care must be taken, however, to consider 
the physical forces the system will be subject to. No conductive 
material should come in contact with the ACB-35 30 PC card. 
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3.2,2 EE CONSIDERATIONS 



The ACB-35 30 and all other partially shielded electronic devices 
are sensitive to high power, high frequency or magnetic sources. 
The controller should be protected from such sources. In 
particular, unshielded switching power supplies should be 
physically isolated form all electronic boards and 
interconnecting cables. Additional cable shielding may be 
required in some environments. 



i^l ACB-3530 £&&IiIHS 

The ACB-35 30 is connected into the host system or subsystem using 

board connectors Jl, J2 and J3. The connectors are used as 
follows: 

Jl- 5 0 Pin QIC-36 Connector (Section 4.1) 

J2- 4 Pin Power Connector (Section 3.3.1) 

J3- 50 Pin SCSI Connector (Section 5.2) 

Figure 3-1 shows proper system cabling. Take care to note pin 1 
orientations of all connectors. These are easily found by 
locating the square solder pad on the solder side of the PC 
board. 

Note: If the ACB-3530 is not the last controller on the SCSI bus, 
the SCSI terminators, RP1, RP2 and RP6 should be removed. 




Figure 3-1. ACB-3530 System Cabling 
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3.3.1 ACB-35 30 PO WER CONNECTQRr jI2 

Figure 3-2 shows the pin assignments for power connector, J2. The 
suggested mating connector to J2 is AMP P/Nl-4 804 24-0 or 
equivalent. 



© +12V 

© + 12V RETURN 

© +5V RETURN 

© +5V 



Figure 3-2. Power Connector, J2, Pin Assignments 



1*± ACB-3530 CONFIGURATION 

The ACB-35 30 requires a minimum of hardware setup. Four jumper 
pairs on header J4 configure the controller SCSI bus address 
and type of attached tape drive (optional). One jumper pair at J5 
enables and disables SCSI bus parity. 

The function of each jumper pair on J4 is shown in Table 3-1, 
sections 3.4.1 and 3.4.2 detail these functions. 



Table 3-1 ACB-35 30 Configuration Jumpers, J4 



G 


1 0 


0 


H 


- SCSI Bus Address 2° 


£ 


1 o 


0 


F 


- SCSI Bus Address 2 1 


C 


1 o 


0 


D 


- SCSI Bus Address 2 2 


A 


1 o 


0 


B 


- 4/9 Track Tape (optional) 



3.4.1 SCSI BjjS AppR ES S 

The installation of jumpers C-D, E-F and G-H set the address ID 
of the ACB-35 30 on the SCSI bus. SCSI devices can have bus 
addresses of 0 to 7, however no two devices may have the same 
address. A jumper installed indicates a logical 1 bit address. 
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3,4.2 £Z1 track TA P E privp (opt io na l) 



The installation of jumper A-B indicates whether the attached 
tape drive is a 4 or 9 track drive. This jumper is optional in 
that the Mode Select (15 H ) and Set Parameters (06fj) command can 
also be used to indicate this. The A-B jumper installed 
corresponds to a 4 track tape drive. 



SCSI £H£ P ARI T Y PNAELE 

The installation of jumper, J5 in the A-B position, will enable 
the ACB-35 30 to check odd bus parity on all data transferred from 
the host. This j um per in the B-C position wil 1 disabl e bus parity 
checking. If the attached host does not generate parity, parity 
must be disabled. The ACB-35 30 will always generate odd parity on 
data transferred to the host. 



P QKBRIN S QM TM ACB-353Q 

The ACB-35 30, once properly cabled and configured, can be 
powered-on. Power should not be applied to the controller if 
activity is present on the attached SCSI bus. The electrical 
nature of the components typically used to drive this interface 
could interrupt bus activity. 

Upon power-on, the controller will execute internal diagnostics 
checking the health of the major components of the controller. 
This self test lasts approximately 10 seconds, any attempt to 
access the controller during this period will result in an SCSI 
Busy status. 

If a cartridge is installed in the attached drive at power-on, 
the controller will rewind it to BOT to prepare for read and 
write accesses. 

If a cartridge is installed some time after power-on, it will be 
rewound by the controller upon insertion. 

The controller will present a Busy status to any access attempts 
made during the power-on or cartridge insertion tape rewind. 
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4.0 QIC-36 1/4" STREAMING TAPE INTERFACE 



The QIC-36 interface provides a low cost, high performance, 
standard interface for attaching a 1/4" streaming tape drive to 
intelligent controller/formatters. This sections describes the 
interface between the ACB-35 30 and a QIC-36 tape drive. 



UL QIC-36 INTERFACE SIGMLS 

The QIC-36 interface is implemented through a 50 pin dual in-line 
header located at position Jl on the ACB-3530. The suggested 
mating connector is 3M P/N 3425 -60XX, 3425-70XX or equivalent. 
Maximum cable length is 10 feet (3 meters) . 

The connector pins are numbered 1 to 5 0. All odd pins are signal 
returns and are connected to the controller board ground. Table 
4-1 shows Jl pin assignments. 



Table 4-1. QIC-36, Jl , Connector Pin Assignments 



Si gna l 



Source 



Description 



Return 



Return 



1 
3 
5 
7 
9 

11 
13 
15 
17 
19 
21 
23 
25 
27 
29 
31 
33 
35 
37 
39 
41 
43 
45 
47 
49 



o 
o 
o 



o 
o 
o 
o 

0 



o 
o 
o 
o 
o 
o 
o 
o 
o 
o 

0 

o 
o 
o 
o 
o 



o 



o 
o 
o 
o 
o 
o 
o 
o 
o 
o 
o 
o 
o 
o 
o 
o 
o 



o 
o 
o 
o 
o 
o 



o 



o 



2 
4 
6 
8 

10 
12 
14 
16 
18 
20 
22 
24 
26 
28 
30 
32 
34 
36 
38 
40 
42 
44 
46 
48 
50 



GO- 

REV- 

TR3- 

TR2- 

TR1- 

TR0- 

RST- 

DS3- 

DS2- 

DS1- 

DS0- 

HC- 

RDP- 

UTH- 

LTH- 

SLD- 

CIN- 

USF- 

TCH- 

WDA- 

WDA+ 

TDH- 

HSD- 

WEN- 

EEN- 



C Tape Motion Enable 

C Tape Direction Control 

C Track Select 2^ 

C Track Select 2 2 

C Track Select 2* 

C Track Select 2° 

C Reset (Initialize Drive) 

C Reserved (not used) 

C Reserved (not used) 

C Reserved (not used) 

C Drive Select 0 

C High Write Current 

D Read Data (Pulse Output) 

D Upper Tape Position Code 

D Lower Tape Position Code 

D Drive Select Response 

D Cartridge In Place 

D Unsafe (No Write Protect) 

D Capstan Tachometer Pulse 

C Write Data Signal - 

C Write Data Signal + 

C Threshold (35% Read Mrgn) 

C High Speed Slew Select 

C Write Enable 

C Erase Enable 
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A detail of the QIC-36 interface signals follows: 



Go (GO-) : Assertion of GO- causes a start tape motion sequence 
in the direction specified by the state of REV-, 

Reverse (REV-): Assertion of REV- will cause tape motion in the 
reverse direction if GO- is asserted. Deassertion of 
REV- will cause tape motion in the forward direction. 

Track Select (TR0-, TRl- r TR2-, TR3-) : Assertion of the track 
select signals will result in the selection of track 0 
through 3, on a 4 track drive, or 0 through 8, on a 9 
track drive. Track selection is made through binary 
assertion of these lines with TRO- the least 
significant. 

Reset (RST-) : Assertion RST- will cause the tape drive to 
reinitialize. This sequence differs between drive 
vendors. 

Drive Select (DSO-)/ Drive Selected (SLD-): The assertion of 
DSO- selects the attached tape drive to allow all tape 
operations to proceed. The drive selected signal (SLD-) 
will be asserted by the drive in response to selection. 

High Current (HC-) : Assertion of HC- enables the tape drive to 
use a higher write current when writing to the drive. 

Read Data Pulses (RDP-) : Serial read data is passed to the 
controller as a pulse for every flux change. Since no 
read enable is required, Read Data Pulses will be 
present any time data passes under the tape read head 
and DSO- is asserted. 

Upper Tape Hole (UTH-) / Lower Tape Hole (LTH-) : The UTH- and 
LTH- signals are generated by the drive to indicate 
some media status. The BOT, Load Point, Early Warning 
and EOT tape holes are encoded to produce an output 
code indicating specific positions of the tape. 

Cartridge In (CIN-): The CIN- signal is asserted by the drive 
when a cartridge tape is fully installed and DSO- is 
asserted. The line is deasserted when the cartridge is 
removed. 

Unsafe (USF-) : The USF- signal is asserted by the drive to 
indicate that the installed cartridge is not write 
protected. This signal will be asserted when the write 
protect plug is in the unsafe position and DSO- is 
asserted. 
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Tachometer Pulses (TCH-) : The tachometer pulses generated by the 
rotation of the capstan motor inform the controller 
when the tape is in motion and how fast. DSO- must be 
asserted for this signal to be valid. 

Write Data (WDA+, WDA-) : WDA line are differentially driven and 
contain tape write data from the controller. WEN- must 
be assserted prior to writing to the tape. 

Threshold (THD-) : Assertion of THD- invokes a 35% qualifying 
amplitude for the read signal. This is typically used 
to eliminate marginal tape recording areas. 

High Speed (HSD-) : Assetrion of HSD- causes 30ips tape drive to 
operate at 90ips speed. 

Write Enable (WEN-): Assertion of WEN- allows write data to be 
written to the tape. 

Erase Enable (EEN-) : Assertion of EEN- enables erase current to 
the full tape width erase head. DSO- and TRO- must also 
be asserted. 



The ACB-3530 is designed to read and write user data, control 
information and file marks in the QIC-24 and QIC-11 media 
formats. Both media format standards are supported with a 512 
byte block size and are shown in Figure 4-1. 



NUMBER 
OF BYTES 



12.5 (MIN.) 


0.5 


512 


1 


2 



GAP SYNC DATA BLOCK CRC 

NUMBER 

QIC-11 BLOCK FORMAT 



NUMBER 
OF BYTES 



13.0 (MIN.) 


0.5 


512 


4 


2 



GAP SYNC DATA BLOCK CRC 

NUMBER 

QIC-24 BLOCK FORMAT 



Figure 4-1. QIC-11 and QIC-24 Block Format 
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4 «2 .1 FILE? HARKS 



Data blocks can be used to create "marks" on the tape, typically 
between recorded files. File marks are written to the tape when 
specified by the host using a unique data pattern in the 512 byte 
data field. The host can then use file marks as boundaries for 
spacing and streaming reads. 



Data is read and written in a serpentine fashion between the tape 
early warning holes; Load point and Early warning. When the 
controller encounters the end of a track, the tape reverses 
direction and continues the read or write. Even numbered tracks 
are recorded while the tape is moving forward. Odd numbered 
tracks are recorded while the tape is moving backward. The 
controller reports an overflow state when the end of the last 
track is encountered (Early Warning). While writing on track 0, 
the tape erase head will be activated ahead of the write data. 
Figure 4-2 shows the layout of an entire 1/4" tape and the 
relative location of the tape postioning holes. 



"FORWARD" DIRECTION 
OF TAPE TRAVEL (OXIDE 
SIDE OF TAPE SHOWN) 




Figure 4-2. 



1/4" Tape Layout 
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TAPE ME DIA PB P fi CT handling 



The ACB-35 30 checks each block on the tape for good CRC as it is 
being written. However, since the tape read head trails the write 
head by about 300 bytes, the CRC results for a given block (block 
N) are not known until the next block write has begun. The 
controller, therefore, assumes that the previous block will check 
correctly and begins writing the next block as such. 

If the CRC check should fail, typically due to a media defect, 
the ACB-35 30 will complete the current block write (N+l) and then 
rewrite the previous block (N). This alternation between N and 
N+l will continue until a successful CRC check of block N is 
achieved or 16 unsuccessful writes have been attempted. If block 
Nwere the last block to be written, it would be repeated until a 
good CRC check is made. This results in the last block of each 
write to be written at least twice. 

This process is effective in that the ACB-35 30 will not attempt 
to read N+l until a valid read from block N is made. 
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5.0 SCSI INTERFACE DESCRIPTION 



This section briefly describes the SCSI protocol implemented by 
the ACB-3530. The SCSI protocols are further defined in the ANSI 
X3T9.2 specification, revision 14B. 



ggflERAL DESCRIPTION Q£ .SCSI 

The SCSI is a device independent method of interfacing up to 8 
host computers and peripheral devices. Device independence 
relates to the abiltiy to communicate with a number of peripheral 
types without regard to the physical characteristics of the 
device (ie. # of tracks, tape capacity, etc). 

The SCSI interface, based on the IBM block multiplexer I/O 
channel, provides optimum performance in host to host and host to 
peripheral communication. The SCSI is implemented through a 50 
pin ribbon cable that is daisy chained to all attached hosts and 
peripheral controllers. The SCSI can support up to 8 devices. A 
single device, such as a disk controller, can support a number of 
peripherals. The daisy chained SCSI cable must be terminated at 
both ends. Figure 5-1 shows the ACB-3530 in a typical SCSI 
configuration. 



Communication occurs across the bus in an Request/Acknowledge, 
asynchronous fashion. The asynchronous bandwidth of the SCSI bus 
is 15 Mbyte/sec maximum. When two devices communicate across the 
bus, the device initiating the command assumes an INITIATOR role, 
the other device required to execute the command is designated as 
the TARGET. Host computers are almost always INITIATORS, 
controllers are almost always TARGETS in SCSI transactions. 
Commands are transferred and executed across the bus using a 
number of bus "phases." The phases determine what type of 
information (command, data, status, etc.) is being transferred 
at any given time. 

In order to execute a command, the INITIATOR (host) must first 
gain control of the SCSI bus, this is accomplished through 
arbitration. The host then selects the required controller: From 
this point on, the controller determines all bus phases and byte 
transfers. The host interface must make no assumption regarding 
the sequence of bus phases, as error conditions can cause the 
controller to change the bus state in the middle of command and 
data transfers. 
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Figure 5-1. Typical SCSI Configuration 
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5_*2 EES SIGHALS 



The SCSI bus contains 9 control signals, controlling the bus 
phase and all byte transfers, and 9 data signals. The interface 
is implemented using a 50 pin dual in-line header at location J3. 
All odd numbered pins are ground. The suggested mating connector 
is 3M P/N 3425-6 0XX, 3425-70XX or equivalent. 

Table 5-1 shows the SCSI, J3, pin assignments. 

Table 5-1. SCSI Connector, J3 , Pin Assignments 



Return 



Return 

N/C 
Return 



Return 











Sianal 


De s crJL v t ion 


1 


1 o 


o | 


2 


DB0- 


Data Bit 0 


3 


|o 


o | 


4 


DB1- 


Data Bit 1 


5 


1 o 


o I 


6 


DB2- 


Data Bit 2 


7 


1 o 


o I 


8 


DB3- 


Data bit 3 


9 


1 o 


o 1 


10 


DB4- 


Data Bit 4 


11 


1 o 


o I 


12 


DB5 - 


Data Bit 5 


13 


1 o 


o I 


14 


DB6- 


Data Bit 6 


15 


|o 


o I 


16 


DB7- 


Data Bit 7 


17 


1 o 


o I 


18 


DBP- 


SCSI Bus Parity Bit 


19 


|o 


o 1 


20 


GND 


Ground 


21 


1 o 


o I 


22 


GND 


Ground 


23 


|o 


o I 


24 


GND 


Ground 


25 


1 o 


o I 


26 


TPWR 


Bus Terminator Power 


27 


|o 


o 1 


28 


GND 


Ground 


29 


|o 


o ! 


30 


GND 


Ground 


31 


|o 


o I 


32 


ATN- 


Attention 


33 


lo 


o I 


34 


GND 


Ground 


35 


lo 


o I 


36 


BSY- 


Busy 


37 


|o 


o I 


38 


ACK- 


Acknowledge 


39 


lo 


o I 


40 


RST- 


Reset 


41 


1 o 


o I 


42 


MSG- 


Message. 


43 


lo 


o I 


44 


SEL- 


Select 


45 


1 o 


o I 


46 


C/D- 


Control/Data 


47 


lo 


o I 


48 


REQ- 


Request 


49 


lo 


o 1 


50 


I/O- 


Input/O utput 



A description of each signal is as follows: 

Busy (BSY-) : BSY- is an "or-tied" signal that indicates that the 
bus is in use. The ACB-35 30 will assert busy upon being 
selected by an SCSI host. 

Select (SEL-) : SEL- is an "or-tied" signal that is used to 
select an SCSI device. The SEL- line can be used by a 
host to select a controller to initiate a command or by 
a controller to reselect a host to complete a command 
(see Section 5 .3). 
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Input/Output (I/O-): I/O is driven by the controller to indicate 
the direction of information transfers on the SCSI bus 
relative to the host. Assertion of this signal, In, 
indicates a controller to host transfer. Out indicates 
a host to controller transfer, 

Control/Data (C/D-) : C/D- is driven by the controller to 
indicate whether a control or data byte is being 
transferred across the bus. The type of control 
information is indicated by the I/O line. Inbound, 
controller to IN ITATOR, control information is status. 
Outbound control information is commands. I/O also 
indicates the direction of data transfers. 

Message (MSG-): MSG is driven by the controller to indicate a 
request to send or receive an SCSI message. This signal 
will be asserted when the controller desires to send a 
message or in response to the host asserting ATN-, 
indicating a host request to send a message. 

Attention (ATN-) : ATN- is driven by the host to indicate a 
request to transfer a message to the selected 
controller. 

Request (RBQ-) : REQ- is driven by the controller to initiate the 
REQ/ACK asynchronous handshake of a byte of information 
to or from the host. The type of information is 
indicated by the C/D-, I/O- and MSG- signals. 

Acknowledge (ACK-) : ACK- is driven by the host to complete the 
REQ/ACK asynchronous handshake of a byte of information 
to or from the host. 

Data Bits and Parity (DBO- to DB7-, DBP-): The SCSI contains an 
8 bit parallel bus, plus odd parity. DBO- is the least 
significant. 
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^1 .SCSI 22£ P H ASES 



The SCSI bus has eight distinct operational phases that are 
controlled by the ACB-3530 by the assertion of one or more of; 
C/D, I/O, MSG, SEL and BSY. The eight phases are: 



0 


Bus Free 


0 


Arbitration 


0 


Selection 


0 


Re- select ion 


o 


Command * 


0 


Data * 


0 


Status * 


0 


Message * 



* Information transfer phases 

In execution of SCSI operations, the bus will sequence through a 
number of these phases. When the bus is between phases, the BSY, 
SEL, REQ and ACK signals may not change. The C/D, I/O, MSG and 
data lines may change. 

The following sections describe the sequence of events contained 
within each bus phase, refer to figure 5-2 and section 5.5 for 
relative bus timing. 



5.3.1 MS FREE P SfigE 

The Bus Free phase, indicating that the bus is free and available 
for use is entered by the deassertion and passive release of all 
bus signals. At the completion of an SCSI operation, the active 
device(s) must deassert all bus signals within 800 nS of 
releasing BSY. 

SCSI devices sense the Bus Free phase when SEL and BSY are 
deasserted and the Reset condition is not active 



5.3.2 ARBITRATION PHASE 

The Arbitration phase allows one SCSI device to gain conntrol of 
the bus in systems where more than one device may require the use 
of the bus. Systems with one host and SCSI devices that do not 
support reconnection may skip this phase by entering the 
Selection phase directly from Bus Free. 

The sequence of arbitrating for the bus is as follows: 

1) Wait for Bus Free phase: deassertion of both SEL and BSY. 

2) After Bus Free is detected, the arbitrating device waits 
a minimum of 800 nS (bus free delay) to assert BSY and 
the data bit corresponding to the device's SCSI address 
ID. 
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3) The arbitrating device then looks on the data bus for an 
ID of higher priority. If no higher priority IDs are 
present, the device has won control of the bus. If higher 
priority IDs exist the device returns to step 1. 

4) After winning arbitration, the device asserts SEL and 
enters the Selection or Reselection phase. 



5 .3.3 SELECTION PHAS E ? 

The Selection phase allows an INITIATOR (host) with control of 
the bus to select a TARGET (controller) to initiate an SCSI 
command. 

The sequence for a host to select a controller is as follows: 

1) To select a device in nonar bi trating systems, the host 
asserts the controller ID address bit and optionally 
asserts its own ID. 

When selecting a device from the Arbitration phase, the' 
host already has SEL asserted (along with BSY). The host 
asserts the controller ID and its own ID and then 
deasserts BSY. 

2) On detecting the simultaneous condition of SEL and its 
own ID asserted, and I/O and BSY not asserted, the 
selected controller examines the data bus for the host ID 
and responds by asserting BSY. 

3) The host then deasserts SEL and ID address data bits. 



5 .3.1 RESELECTION PHASE 

The Reselection phase is used to re-establish a connection 
between a host and controller in order to continue a disconnected 
operation. This phase is entered from the Arbitration phase. Like 
the Selection phase, the SCSI device with control of the bus has 
both SEL and BSY asserted. The Reselection phase differs from the 
Selection phase by the assertion of I/O. 

The sequence for a controller to reselect a host is as follows: 

1) The controller asserts I/O and the data bits 
corresponding to its own ID address and the desired host 
ID address. The controller then deasserts BSY. 

2) On detecting the simultaneous condition of SEL, I/O and 
its own ID asserted and BSY not asserted, the reselected 
host examines the data bus for the controller ID and 
responds by asserting BSY. 
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3) After detecting the assertion of BSY, the controller also 
drives BSY and then releases SEL and the ID address bits. 

4) The host then deasserts BSY leaving the bus in the same 
state as at the completion of the Selection phase. 



5.3,5 INFORMATION T RANSFER PHASES 

The Command, Data, Status and Message phases are used to transfer 
data or control information across the data bus. 

The C/D, I/O and MSG signals are used to differentiate the 
various information transfer phases. These signals are not 
considered valid unless REQ is asserted. Table 5-2 shows the bus 
phases related to the C/D, I/O and MSG signals. 



Table 5-2. Information Transfer Phases 
Signal 

Direction of 



MSG 


C/D 


I/O 


Phase 


Inf romation 


Xfer 


0 


0 


0 


Data Out Phase 


Host to ACB- 


■35 30 


0 


0 


1 


Data In Phase 


ACB-35 30 to 


host 


0 


1 


0 


Command Phase 


Host to ACB- 


-35 30 


0 


1 


1 


Status Phase 


ACB-35 30 to 


Host 


1 


0 


0 


- Not Used 






1 


0 


1 


- Not Used 






1 


1 


0 


Message Out Phase 


Host to ACB- 


■3530 


1 


1 


1 


Message In Phase 


ACB-35 30 to 


Host 



Note: "1" indicates signal assertion (SCSI bus signals are 
negative true) 



The Information Transfer Phases use the REQ/ACK handshake to 
control data transfers. Each REQ/ACK allows the transfer of one 
byte of data. The handshake starts with the controller asserting 
the REQ signal, requesting a byte transfer. The host responds by 
reading or writing a byte of data from/to the bus and asserts 
ACK. The controller then deasserts REQ, causing the host to 
deassert ACK. See Figure 5-2. 
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1 

CONTROLLER REQ 



' r-riMTDOl I CD DDCQCMTQ HATA > f 



0 f CONTROLLER PRESENTS DATA 



HOST ACK 



JZ 



HOST TAKES DATA 



\ 



CONTROLLER DATA 



ACB-3530 TO HOST TRANSFER 



1 

CONTROLLER REQ 



1 

HOST ACK 



0 / CONTROLLER TAKES DATA ^ ^ 

JZ 



0 ' — HOST PRESENTS DATA 



HOST DATA 



HOST TO ACB-3530 TRANSFER 



1 = SIGNAL ASSERTED 
0 = SIGNAL DEASSERTED 



Figure 5-2. REQ/ACK Handshake 



A controller to host data transfer (I/O asserted) occurs with the 
ACB-3530 placing data on the bus, assuring it is valid at the 
host interface, and asserting REQ. The host then reads the data 
and asserts ACK. 

A host to controller transfer (I/O deasserted) occurs with the 
controller asserting REQ, requesting a byte of data from the 
host. The host places data on the bus, assuring it is valid at 
the controller interface, and asserts ACK. 

The BSY signal remains asserted throughout the Information 
Transfer Phases. 
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5 . 3 .5 . 1 COMMAND PHASE 



The Command phase is used by the ACB-3530 to obtain Command 
Descriptor Blocks (CDB) from the host. The sequence for a command 
transfer is as follows: 

1) A host, in order to execute a command, arbitrates for 
the bus (if arbitrating system) and selects the ACB-3530. 

2) The ACB-3530 becomes selected and places the bus in a 
Command phase with RBQ asserted. 

3) The command is passed, in a 6 byte block, to the ACB-35 30 
using the REQ/ACK handshake and begins execution. 

Section 5.6 details the content of an SCSI Command Descriptor 
Block. 



5 .3.5 .2 DATA PHASE 

The Data phase includes both Data In and Data Out. The Data In 
phase is used by the ACB-3530 to transfer tape data or control 
information (ie. error codes or configuration data) to the host. 
The Data Out phase is used by the host to transfer tape write 
data or control information to the ACB-3530. 

The Data phase is typically entered after the Command phase and 
like command transfers, data is transferred using a REQ/ACK 
handshaking. 



5 .3.5 .3 STATUS PHASE 

The Status phase is used by the ACB-3530 to inform the host of 
the state in which the last command completed. The controller can 
enter the Status phase at any time to indicate a detected error. 
If an error is detected during the 6 byte command transfer, the 
ACB-3530 will transfer all 6 bytes and then enter the Status 
phase. The controller will immediately invoke the Status phase if 
an error is encountered during a data transfer. Status 
information is transferred in a single byte from the controller 
to host. Section 5.7 details the SCSI status information. 



5.3.5.4 MESSAGE PHASE 

The Message Phase includes both Message In and Message Out. The 
Message In phase is used by the ACB-3530 to transfer a control 
message to the host (ie. prepare to disconnect). The Message Out 
phase is used by the host to transfer a control message to the 
controller (ie. abort operation). In order to enter the Message 
Out phase the host must assert the ATN line which causes the 
controller to accept the message. Section 5.8 details the 
messages supported by the ACB-35 30. 
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5.3,6 SCSI £US PHA SE SEQUENCING 



The execution of commands typically consists of a number of SCSI 
bus phases. Figure 5-3 shows a typical sequence of bus phases. 



BUS FREE PHASE 



ARBITRATION PHASE: HOST 
ARBITRATES AND GAINS CONTROL 
OF BUS. 



SELECTION PHASE: HOST 
SELECTS CONTROLLER. 



ATTENTION 



ERROR 



COMMAND PHASE: HOST 
TRANSFERS 6 BYTE 
COMMAND TO CONTROLLER 
WITH REQ/ACK HANDSHAKE. 



ERROR 



DATA PHASE: DATA 
TRANSFERRED TO OR FROM 
THE HOST. 



STATUS PHASE: CONTROLLER 
REPORTS STATUS TO HOST. 



MESSAGE PHASE: COMPLETION 
MESSAGE 00„ TRANSFERRED 
TO HOST. 



IF DISCONNECT IS SUPPORTED: 



MESSAGE PHASE: HOST 
INFORMS CONTROLLER OF 
ABILITY TO DISCONNECT. 
—IDENTIFY 



MESSAGE PHASE: CONTROLLER 
INFORMS HOST OF DISCONNECTION. 
—SAVE DATA POINTERS 
—DISCONNECT 



BUS FREE PHASE 



ARBITRATION PHASE: CONTROLLER 
ARBITRATES TO RECONNECT AND 
GAINS CONTROL OF THE BUS. 



RESELECTION PHASE. 

CONTROLLER RECONNECTS 
TO HOST. 



MESSAGE PHASE: CONTROLLER 
IDENTIFIES RECONNECTING LUN. 
— IDENTIFY 

— RESTORE DATA POINTERS 



BUS FREE PHASE 



Figure 5-3. SCSI Bus Phase Sequencing 
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5l^1 MS CONDITIONS 



The SCSI bus has two conditions that can interrupt normal phase 
sequencing and initiate certain device activity. These are the 
Attention and Reset Condition. 



5.4.1 AT TENT I ON CO ND ITION 

The Attention condition allows the host to signal the ACB-35 30 of 
a waiting message. The ACB-3530 accesses the message by invoking 
a Message Out phase and handshaking the message from the host. 

The host may create the Attention condition by asserting ATN at 
any time except during the Arbitration and Bus Free phase. When 
the message byte is to be transferred the host deasserts the ATN 
signal once the Message Out phase is entered. 

The ACB-3530 may not be able to respond to the Attention 
condition immediatly so the host must continue to support the 
other bus phases while ATN is asserted. 



5.4.2 RESET CON D I T IO N 

The Reset condition is used by the host to clear all devices from 
the SCSI bus. This condition is created by asserting the RST 
signal. 

Reset can occur at any time and takes precedence over all other 
bus phases and conditions. On reset, all devices immediately 
deassert and passively release all bus signals, thus entering a 
Bus Free phase. 

The RST signal must stay asserted for at least 25 uS, while 
asserted, no other bus signals can be assumed valid. 

The ACB-35 30 supports the SCSI "hard" reset mode. Upon reset, the 
ACB-3530 releases all bus signals and immediatly clears any 
commands in process. The ACB-35 30 will also rewind the tape to 
BOT. 

The next command to the ACB-3530 after reset will result in a 
Check status. The Request Sense (15 h) command will return a sense 
key Unit Attention (6). 



5-m5l .SCSI JftHS 

SCSI bus timing is shown in Figure 5-4. The SCSI specification 
can provide further timing detail if required. 
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Bus set delay ' = max time from check of bus tree iBSV S SELL not asserted) 
until assertion ot BSY and ID n 8 nS) 

Bus free delay - mm time bus must be left tree (800 nsi 
Bus dear delay - time to clear from bus after drop of BSY for bus tree pnase 
or asserting of SEL tor arbitration phase by other device (800 nsi 



(Busy) 
(Select) 



+BSY 
+SEL 



(Control/Data) +CD 
(Input/Output) +I/0 



Arbitration delay - mm time from asserting BSY 
to check if arbitration is won (2 2 nSl 



(Request) 

(Acknowledge) 

(Attention) 

(Message) 



+ REQ 

+ACK 
+ATN 
+ MSG 



Bus seme delay (400 nsi 




hDB (7-0. P) 



7 



Systems with 
no arbitration 
start here 



Bus 
Free 



Initiator tni 
to get bus 



f~ " ARBITRATION ~~ ^ 
k PHASE _^ 



Initiator ID & target iO 



Initiator nas bus and 
selects taiget 



Note 

nB , 7l = Most significant bit 
uo "'= Hrghest priority 10 lor art 
Note 

OB(P) = Data parity (odd) 
Parity is not valid 
during arbitration 
The useot parity is a 
system option 
Note 

In a typical system, a computer >. 
host adapter will act as the 
initiator and an I/O 
device s control unit will act 
as the "target 



After initiator sees 
that bus is free 
( BSY & SEL are not 
assertedi it waits a 
mm ot bus free 
delay and a max of 
bus set delay and 
asserts BSY and its 
own 10 on the data 
bus 



After the arbitration 
delay the initiator 
checks the data bus 
and clears itself from 
arbitration it a higher 
priority l0iDB(7l = 
highest) is on the bus 



1 — II SEL" is asserted 
during arbitration by 
another device the 
initiator will immedi- 
ately clear itself from 
arbitration (within 
"bus clear delay " time) 



If the initiator deter- 
mines that its own ID 
is the highest asserted 
then it may not change 
any lines until after 
waiting two bus settle 
delays I 



L 

L 



SELECTION " 
DESELECTION) 
PHASE 



Initiator asserts data bus 
with desired target s ID & 
its own (initiator) ID (For 
RESELECTION. I 0 is also 
asserted ) 

After two deskew delays 
the initiator drops BSY 

The selected target sees 
the condition o 1 BSY not 
asserted while SEL & its 
ID are asserted The target 
responds by asserting 
BSY 



Alter two deske* delays 
the initiator drops SEL 
and may change the data 



Note After initiator drops 
SEL it is the only bus 

device that can assert 
ACK and ATN land the 

data lines it I/O is not 

asserted nndicatmg ouf- 

put trom initiator! 



Note Alter the target sees 
drop ot SEL the target is 
the only bus device that 
can assert BSY C/0 
■1/0 MSG "REO (and 
the data imes if I/O 
is asserted (indicating 
input to the initiator! 



Note In systems in which the arbitration phase is not 
implemented the initiator tirst detects the bus free phase 
( BSY & SEL not assertedi and then waits a 
"bus settle delay Then the initiator asserts the 
data bus with the desired target s ID and its own (initiator) 10 
Then alter two deskew delays the initiator asserts SEL 
Then as described above the target responds 
with BSY and the initiator drops SEL 

Note This phase will be followed by 
MESSAGE in phase lor RESELECTION 



Figure 5-4. SCSI Bus Timing 
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Bus settle delay' (400 nsi 



(Busy) +BSY 

(Select) +SEL 

(Control Data) + CD 

(Input/Output) -I/O 

(Request) + REQ 

(Acknowledge) + ACK 

(Attention) +ATN 



(Message) 
(Reset) 



-MSG 



-RST 



(Data Bit) -rDB (7-0. P) 




I CMD byte Last CMD byte 

Tar cf-: reauests 
co tT "Tians from 



command phase 



First data twnte peripheral! 



"Last data (write peripheral! 



Target requests data 
transfer with initiator 



Targe' asserts 
C u ar.c-does not 

asse'i I 0 or 
MSG 



A1!6' a Ol'S 

sei'if d? 'a> tar- 
get asse*is RED 



Initiate!' puis 
data ■ commansi or 
the bus anc asserts 
ACK 



Target waits a 
desne* deray 
takes the data & 
thend'ops REO 



Note To mamtam ANSI 
compatibility initiator 
should deskew the data 



> £ 



Read peripheral device 



L T ar 



aet asserts I/O and does no! assert C/'D or 
MSG Targe: then waits at least a Bus settle 
delay Detore asserting REO 



L 

L 

I — Data are no longer guaranteed valid 
I — Target drops REO 

u 



Target also puts data on the Dust at least 
deskew delay before the assertion of REO 



Initiator takes data ana asserts ACK 



Initiator drops ACK 
Write peripheral device 



Target asserts REO and does not assert 
I/O CD or MSG 



Initiator asserts ACK & data 



Target waits a deskew delay then takes 
the dala & then drops REO 



Data are no longer guaranteed valid 



Initiator drops ACK 



Figure 5-4. SCSI Bus Timing (con't) 
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Reset ho'd time -■ 25 uS 
SEL reponse t.meout - 250 ms 
MAX ' caciie skew = 10 ns 



(Busy) -t-BSY 

(Select) ^SEL 

(Control Data) -C D 

(Input'Output) -10 

(Request) -REQ 

(Acknowledge) -ACK 

(Attention) *ATN 



Oeskew Delay Time (45 nsi 

ae>», a»o*s t-» 45 ns 
. 'ece'.e' Ske* ana 10 ' 

' CIS 1 " SkCA 



(Message) 
(Reset) 



-MSG 



-RST 



(Data Bit) -DB (7-0. P) 




• Status byte 



Status oyte 
Target 
requests 
initiate to 

A take status 1 

/ STATUS \ 
\ PHASE ) 

I y~ (Ending status) ~~y 



Target asserts 
CO & 10 
and does not 
assert MSG 
After a bus 
settle delay 
it asserts 
REQ 



I — Target also 
asserts data 
(status; at 
least a des- 
kew deiay 
before REQ 



L 
L 

L 



initiator takes 
data ano asserts 
ACK 



Data are no long- 
er guaranteed 
valid 



Target drops 
RED 



Initiator drops 
ACK m 

response to the 
drop Ot REQ 



Note In theory 
more than one 
status byte 
could be sent 



Message byte 

Target requests 
initiator to take 
messaae 



(~ MESSAGE > 
\_ PHASE _/ 



Target asserts 
C D l.'O 
MSG Atier 
bus settle 

delay it 

asserts REO 



Target also 
asserts data 
imessagei at 
least a des- 
kew delay 
before REO 



Note Message 
sent here 
could indicate 
command done 
interrupt 



Initiator takes 
data and asserts 
ACK 



Data are no long- 
er guaranteed 
valid 



Then initiator 
drops ACK in 
response to the 
dropot REO 



Note In theory 
more than once 
message byte 
could be sent 




Note This is an example of 
a typical bus sequence It 
is not a definition of bus 
protocol 



Figure 5-4. SCSI Bus Timing (con' t) 
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£QMHAHD DESCRIPTOR £LQ£K 



Commands transferred from an SCSI host to the ACB-35 30 are in the 
form of a 6 byte block. The command block, Command Descriptor 
Block (CDB), is a predefined format shown in Figure 5- . The CDB 
contains a command opcode, the peripheral device being addressed 
and the number of blocks to be accessed within that peripheral. 

The ACB-35 30 supports the SCSI class 0, 6 byte, command blocks. 



Byte 
00 
01 
02 
03 
04 
05 



Bit 

76543210 
h h ^ + + + + 



Class Code 

■+ + 

Logical Unit 



+ + + + + + h 



Command Opcode 

■+ + +• 

I Vendor Unique 



(MSB) 



-+- 



-+- 
-+- 



-+- -+- 

Block Count 
-+- — +— — H 



-+- 



-+- 



— +— -+- -+- -+- 

(LSB) 

Control Byte 



Figure 5-5. Class 0 CDB Supported by the ACB-35 30 



A description of each CDB field is as follows: 



Class Code: The class codes defined by the SCSI specification 
are 0 through 7. The ACB-3530 supports only class 0, 6 
byte, commands. This field must therefore always be 
zero. 



Command Opcode: The command opcode indicates the command to be 
exectued to the controller. The opcodes defined by the 
SCSI specification are 00 H through 1F H . The commands 
supported by the ACB-35 30 are detailed in Section 6.0. 



Logical Unit Number: The logical unit number refers to the 
peripheral devices attached to the SCSI controller. 
SCSI allows for up to 8 peripherals (logical units), 
however, since the ACB-3530 only supports one QIC-36 
tape drive, this field must always be logical unit 
number 0. 
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Block Count: The number of blocks field indicates the total 
number of consecutive blocks accessed. A data transfer 
will begin at the position of the tape and continue for 
the total number of blocks indicated. 



Control Byte: The control byte is used to indicate SCSI linked 
commands and is used by some vendors for vendor unique 
features. Most ACB-3530 commands do not support any 
control byte extensions. 

The definition of each field within the CDB can vary for each 
SCSI command. Refer to section 6.0 for the CDB for each command 
supported. 



CQHP LqTKffl STA T US BYTE 

A byte of status information is transferred from the controller 
to the host during the SCSI Status phase. The status phase is 
invoked at the completion of every command. If an error state is 
encountered during data transfers or command execution, the ACB- 
3530 will also invoke the Status phase. Errors encountered during 
a "buffered" write operation will be reported with the next 
command. 

Figure 5-6 shows the Completion Status byte. 



Bit 

76543210 

I 0 | 0 | 0 |Rsrvd| Bsy | 0 I Check I 0 I 
+ + + + + + + + + 

Figure 5-6. Completion Status Byte 

A OOh status byte at the completion of a command indicates good 
status, or proper command completion. The ACB-35 30 supports three 
additional status states: Busy, Check and Reservation Conflict. 
Bits 0,2,5,6 and 7 will always be set to zero. Bits 1,3 and 4 are 
described as follows: 



Busy (bit 3): The controller is unable to accept the command 
because of the power-on self test in process or a previous 
command still in process, typically an immediate 
load/unload or rewind. This status will occur immediatly 
after a 6 byte command is transferred. 
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Check (bit 1): An error condition prevented successful 
completion of the active command. The nature of the error 

can be obtained through the Request Sense command (03h)» 
This status can occur at any time during the transfer and 
execution of a command. 



Reservation Conflict (bit 4): A reservation conflict exists. 

When this bit is set with bit 3 f Busy, the command issued 
is in conflict with an existing tape drive reservation. 
This status can be returned as a result of a tape access 
or a reservation request. 



g CS I MPSS AS P SYSTEM 

The message system allows communication between an Initiator and 
an ACB-35 30 for the purposes of physical path management. This 
section describes the messages supported by the ACB-3530. 



5^8*1 SCSI MESSAGE DESCRIPTION 

The ACB-35 3 0 supports SCSI messages to allow disconnect/reconnect 
and provide communication between the host and controller. 

Table 5-3 shows the messages supported by the ACB-35 30. 



Table 5-3. SCSI Messages Supported by the ACB-3530 



Code (in Hex) 


Description 


Pireotion 


00 


Command Complete 


In 


02 


Save Data Pointer 


In 


03 


Restore Data Pointer 


In 


04 


Disconnect 


In 


07 


Message Reject 


In Out 


08 


No Operation 


Out 


80 - FF 


Identify 


In Out 



Command Complete (00 H ) : The Command Complete message is sent by 
the ACB-3530 to indicate that the last command has 
terminated. This message will always follow a valid status 
byte. Immediately after this message the bus will be 
placed in the Bus Free phase. 



Save Data Pointer (02u): The Save Data Pointer message is sent 
by the ACB-35fo to direct the host to save the active 
command execution state prior to disconnect. The host 
typically stores pointers to command, status and data 
areas of memory related to the disconnecting command. 
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Restore Data Pointers (03„) : The Restore Data Pointers message 
is sent by the ACB-3530 to direct the host to restore the 
most recently saved pointers for logical unit indicated in 
the preceding Identify message to the active state. 



Disconnect (04 H ) : The Disconnect message is sent by the ACB-3530 
to inform the host that the present physical path is going 
to be broken by disconnection. This message is always 
preceded by a Save Data Pointers message. Immediately 
after this message the bus will be placed in a Bus Free 
Phase. 



Message Reject (07 H ) : The Message Reject message can be sent 
from either the initiator or target to inform the other 
that the last message sent was either inappropiate or not 
implemented. 



No Operation (08 H ) : The No Operation message is used by the host 
to respond to the Message Out phase when there is no valid 
message to send. 



Identify (80 R to FFji) ; The Identify message is sent by either the 
host or controller to establish a physical path connection 
between the host and the ACB-3530 controller. The format 
of the Identify message is shown in figure 5-7. 



Bit 

7 6 5 4 3 2 1 0 

I 1 jdiscnj 0 | 0 I 0 I Logical Unit # I 

Figure 5-7. Identify Message 



Disconnect (bit 6): This bit is set in a host to 
controller message indicating the host's ability to 
disconnect. This message is sent after controller 
selection. 

Logical Unit Number (bits 0,1 and 2): The logical unit 
number is used to inform the host of the which logical 
unit attached to the controller is reconnecting, or to 
inform the controller which logical unit is being 
selected (if system is disconnecting). 
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6.0 Command Descriptions 



This Section describes the command set implemented by the ACB- 
3530. This command set follows the ANSI X3T9.2, however, 
deviations do occur to support special Adaptec functions. Table 
6-1 summarizes the implemented command set. 



Table 6-1. ACB-35 30 SCSI Command Set 



Command Opcode 



(in hex) Command Section 

00 Test Unit Ready 6.1 

01 Rewind Tape (D) 6.2 
03 Request Sense 6.3 

05 Read Block Limits 6.4 

06 Set Parameters 6.5 
08 Read (D) 6.6 
OA Write (D) 6.7 

10 Write File Mark (D) 6.8 

11 Space (D) 6.9 

12 Inquiry 6.10 

13 Verify (D) 6.11 

14 Recover Buffer Data 6.12 

15 Mode Select 6.13 

16 Reserve Unit 6.14 

17 Release Unit 6.15 
19 Erase (D) 6.16 
1A Mode Sense 6.17 
IB Load Unload Unit (D) 6.18 

(D) Disconnecting commands 
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TE S T W I T RE A D Y (00H> 

This command returns the status of the attached tape drive. A 
good completion status, 00h status byte, indicates the drive is 
powered-on with cartridge inserted and ready for operation. 
Figure 6-1 shows the CDB for Test Unit Ready. 



Bit 

Byte 7 6 5 4 3 2 1 0 

| + — - — + + + + + + 

00 | 0 0 0|0 0 0 0 0 

01 I Logical Unit # I 0 0 0 0 0 

02 |0 0 0 0 0 0 0 0 

| + + + + + + + 

03 |0 0 0 0 0 0 0 0 

04 |0 0 0 0 0 0 0 0 

05 |0 0 0 0 0 0 0 0 

Figure 6-1. Test Unit Ready Command 



^LJL PQSSIPIS ER fiQR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following error 
codes could be returned from a Request Sense (03h) command: 



Sense Key: 
2 
4 
6 



Error : 
Unit Not Ready 
Hardware Error 
Unit Attention 



Possible Cause: 
See Section 6.3.3 
See Section 6.3.3 
See Section 6.3.3 
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r ewi np cohha np (01 H ) 



This command rewinds the cartridge tape to the beginning of tape 
(BOT). Figure 6-2 shows the CDB for the Rewind command. 

Bit 



Byte 


7 6 5 


■ 


4 


3 


2 


1 0 


00 


10 0 0 


1 


0 


0 


0 


0 1 


01 


1 Logical Unit # 


-+- 

1 


0 


0 


0 


0 I Immed 


02 


10 0 0 


-+- 


0 


0 


0 


0 0 


03 


10 0 0 




0 


0 


0 


0 0 


04 


10 0 0 




0 


0 


0 


0 0 


05 


10 0 0 




0 


0 


0 


0 0 



Figure 6-2. Rewind Command 



If the host does not support disconnect and the Immediate bit 
(byte 01 f bit 00) is not set, this command will return a 
completion status at the end of the rewind process. If the 
Immediate bit is set, the ACB-35 30 will return good completion 
status at the initiation of rewind. During the rewind, the 
controller will return a Busy status in response to all commands. 

If the host has indicated the ability to disconnect (through the 
Identify message), the ACB-35 30 will disconnect during the rewind 
process and reconnect to present ending status. 



P QgS IP kE FRflQ R STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following error 
codes could be returned from a Request Sense (03h) command: 



Sense Key: Error: Possible Cause: 

2 Unit Not Ready See Section 6.3.3 

4 Hardware Error See Section 6.3.3 

6 Unit Attention See Section 6.3.3 



ACB-3530 Users Manual 



6-3 



400112-00A A 



REQUEST SENSE COMMAND (03 H > 



This command returns Unit Sense information for the specified 
logical unit. Unit sense can provide the host information 
regarding a Check status condition, tape access retries, buffer 
status and tape status. Sense information will be valid for the 
last Check status sent to the host. Sense data will be cleared 
upon receiving a subesquent command, from the host that received 
the Check status. Access attempts from other hosts will result 
in a Busy status until the Unit Sense information has been 
cleared. This command, therefore, should always follow a Check 
status. Figure 6-3 shows the CDB for the Request Sense command. 



Bit 



Byte 


7 6 


5 4 




3 


2 




1 




0 


00 


I 0 0 

j + +- 


0 ! 0 




0 


0 




1 




1 


01 


I Logical Unit 


+ 

# | 0 


-+- 
-+- 


— — +- 
0 


0 


-+- 


0 


-+- 
-+- 


0 


02 


I 0 0 


o o 




0 


0 




0 


-+- 


0 


03 


I 0 0 


0 0 


-+- 


0 


0 


-+- 


0 


-+- 


0 


04 


| — + +- 


■ + 

Number 


of 


+_ 

Bytes 




-+- 








05 


| + +- 

I 0 0 
+ +- 


+ 

0 0 
+ 


-+- 
-+- 


+- 

0 

+- 


0 


-+- 
-+- 


0 


-+- 
-+- 


0 



Figure 6-3. Request Sense command 



Number of Bytes (byte 04): This byte specifies the number of 
bytes allocated by the host for returned Unit Sense 
information. A value of 0 will default to 4 bytes; it is 
recommended that 16 bytes be allocated for sense data. 
The controller will return the exact number of bytes 
specified. 

The sense information returned by this command is detailed in 
Section 6.3.2. 



fi^lxlj. POSSIBLE ERROR STATES 

This command could result in a Busy status, see Section 5.7 for 
a description of the possible cause. 

A Check status will not be returned in response to this command. 
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UN IT SPNSE INFORMATION 



Sense information returned as a result of the Request Sense 
command is in the SCSI extended sense format. The sense data 
will be valid for the Check status just presented to the host. 
Sense data will be cleared on any subsequent command from the 
host receiving a Check status. Figure 6-4 shows the format of 
the sense bytes returned by the ACB-35 30. 



Byte 
00 
01 
02 
03 
04 
05 
06 
07 
08 
09 
OA 
0B 
0C 
0D 
0E 
OF 



Bit 
4 3 



+- 

Valid! 



0 I 
FilMk 1 



1 I 1 I 1 I 0 | 0 I 
+ + + + +■ 

0 | 0 | 0 | 0 | 0 | 

EOM I 0 | 0 I Sense 
+ + + + + . 



0 
Key 



| 0 



(MSB) 



-+- -+- -+- -+- -+- -+- 

-+- -+- - Block Count - -+■ 
-+- -+- -+- 

# of Additional Bytes (08) 



■+- 
■+- 

■+- — 
(LSB) 



+- 

0 | 

0 I 

(MSB) 
-+- 

(MSB) 
-+- 

+- 



CNI 



0 



WRP 



EOM 



UDA 



0 | NDA | 0 | BOM | 0 | 
-+ Data Retries Counter -+- 

-+- Under run Counter -+- 

Current Track 
Blocks to Go Count 



BNL 
0 



■+ 

I FIL 

I POR 

■+- 
(LSB) 

•+- 

(LSB) 



Figure 6-4. Sense Information 
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Address Valid (Bit 7, Byte 00): This bit set indicates that the 
information contained in the Block count bytes (03 - 06) 
is valid. 

File Mark (Bit 7, Byte 02): This bit will be set to indicate 
that the last block processed was a file mark. Read, 
Verify and certain Space commands will terminate on a file 
mark. 

End of Media (Bit 6, Byte 02): This bit will be set when the end 
of physical tape warning is encountered while accessing 
the last track of the tape. 

Sense Key (Bits 0-3, Byte 02): The sense key contains the error 
code (if any) that caused the last Check status. A detail 
of possible error codes is contained in Section 6.3.3. 

Block Count (Bytes 03-06): The block count contains the number of 
blocks not processed (written to tape) from all buffered 
and current commands. The use of block count will vary 
with the initial command issued. Refer to the individual 
command detail to determine the meaning of this field. 
The Block Count is only valid if the Valid bit is set. 



The following information, contained in bytes 08 to OF, provides 
additional error, controller state and drive state data. 



Cartridge Not Inserted, CNI (Bit 6, Byte 08): This bit set 
indicates the tape cartridge is not inserted. 

Write Protect, WRP (Bit 4, Byte 08): This bit set indicates the 
inserted drive is write protected, inhibiting tape writes. 

End of Media, EOM (Bit 3, Byte 08): This bit is set to indicate 
the end of physical tape warning has been encountered. 
This bit is identical to bit 6, byte 02. 

Unreadable Data Encountered, UDA (Bit 2, Byte 08): This bit set 
indicates that a block cannot be successfully read or 
written. The ACB-35 30 will retry a read or write 16 times. 

Block Not Located, BNL (Bit 1, Byte 08): This bit set indicates 
that the block the controller is attempting to access, N, 
cannot be found. This will be reported when blocks N+l and 
N+2 are found and not N after 16 attempts. This error may 
occur during any tape access and when locating the last 
block on the tape for appending data. 

File Mark Encountered, FIL (Bit 0, Byte 08): This bit set 
indicates that a file mark has been encountered. This bit 
is identical to bit 7, byte 02. 
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No Data Detected, NDA (Bit 5, Byte 09): This bit is set to 
indicate that a span of erased tape has been encountered. 

Beginning of Media, BOM (Bit 3, Byte 09): This bit set indicates 
that the tape is positioned at the physical beginning of 
the media. 

Power On Reset, FOR (Bit 0, Byte 0 9): This bit set indicates that 
a power-on or SCSI reset has occurred clearing all 
reservations and commands in process. The sense key, Unit 
Attention (06) will always be reported with this bit. 

Data Retries Counter (Bytes 0A-0B): The Data Retries Counter 
contains the number of blocks rewritten due to errors 
during a write operation. During a read operation this 
counter contains the number of soft and hard errors, 
causing tape reposition, encountered. 

Underrun Counter (Bytes 0C-0D) : The Underrun Counter contains 
the number of times a normal streaming operation was 
interrupted because of an underrun or overrrun of data in 
the controller buffer. 

Current Track (Byte 0E): The Current Track contains the track 
number, starting at 0, that the read and write heads are 
currently positioned over. 

Blocks To Go (Byte OF): The Blocks To Go contains the number of 
blocks that have been written into the buffer and not 
written to tape from previously completed and current 
write operations. This information can be used by the 
host to determine the status of a buffered write. 



6.3.3 SENSE KEYS 

The sense key returned in the Unit Sense information, indicates 
the error state causing the last Check status. Generally, the 
sense key should always be checked after a Check status to 
determine the nature of the operational failure. 

The sense keys supported by the ACB-3530 are detailed in Table 
6-2. 
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Table 6-2. ACB-35 30 Sense Keys 



Sense K ey 



Error 



0 

1 

2 

3 

4 

5 

6 

7 

8 

9 

A 

B 

C 

D 

E 

F 



No Sense 
Recovered Error 
Device Not Ready 
Media Error 
Hardware Error 
Illegal Request 
Unit Attention 
Data Protect 
Blank Check 
Not Used 
Not Used 
Aborted Command 
Not Used 
Volume Overflow 
Not Used 
Not Used 



No Sense (0): No sense information available. The last command 
for this LUN was successful. File mark or EOM may have 
been encountered, the appropriate sense bits will be set. 

Recoverable Error (1): The last tape access was successful after 
retries. 

Not Ready (2): The addressed unit cannot be accessed. This can 



be caused by no cartridge inserted, no power applied to 
drive, or a faulty QIC-36 cable. 



Media Error (3): The last tape access was unsuccessful. This is 
likely to due to a flaw in the media. 

Hardware Error (4): The ACB-3530 detected an uncorrectable 
hardware error. This is generally caused by the lack of 
capstan tach pulses from the drive or a faulty QIC-36 
cable. 

Illegal Request (5): There is an illegal parameter in the CDB 



or parameter data last transferred to the controller. A 
Check status condition will be sent immediately after the 
invalid parameter data byte is transferred. If an illegal 
byte is contained in the command, a Check status will be 
reported after the entire CDB is transferred, .pa 
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Unit Attention (6): The tape cartridge has been changed 

(removed and reinserted) or a reset has occurred since the 
last command. This will be returned in response to the 
first command from each host after the condition is 
detected. These commands will result in a Check status and 
not be executed. If this sense key is a result of a device 
reset, power-on or SCSI, the POR sense bit will be set. 

Data Protect (7): A write was attempted to a tape that is write 
protected. 

Blank Check (8): The end of recorded media was encountered 
during a read. The host has attempted to read beyond the 
last recorded block number. 



Aborted Command (B) : The ACB-35 30 aborted the command. The 
command should be reissued by the host. 

Volume Overflow (D) : A completed, buffered, write has reached 
the physical EOM before all the data was written to tape. 

A Recover Buffer Data command (14h> mav be issued to 
recover the data in the buffer. 
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fiE&D 3kQCK LIMITS COMMAND (05 h> 



The Read Block Limits command returns the minimum and maximum 
block size currently written on the tape. The ACB-35 30 supports 
only 512 byte, QIC-24 and QIC-11, formatted blocks. Both the 
minimum and maximum block size will equal 512 bytes. Figure 6-5 
shows the CDB for the Read Block Limits command. 



Byte 
00 
01 
02 
03 
04 
05 



Bit 
4 3 



0 



+ + + +. + + + 

0 0 0 10 0 1 0 1 
+ + + + + + + 

Logical Unit # | 0 0 0 0 0 

0 0 000000 

0 0 0 0 0 0 0 0 

00000000 



0 0 0 
•+ + 



0 0 0 0 
+ + + +■ 



+ + + + + + + 

Figure 6-5. Read Block Limits Command 



Figure 6-6 shows the data returned by the controller in response 
to this command. 



Byte 
00 
01 
02 
03 
04 
05 



Bit 

7 6 5 4 3 2 1 0 

00000000 
(MSB) 




(MSB) 



-+ Minimum Block Length +- 



(LSB) 



Figure 6-6. Read Block Limits Data Returned 
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6.4.1 PQSSIPLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following error 
codes could be returned from a Request Sense (03h^ command: 

Sense Key: Error: Possible Cause: 

2 Unit Not Ready See Section 6.3.3 

4 Hardware Error See Section 6.3.3 

6 Unit Attention See Section 6.3.3 
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£_*5_ .SET PARAMETERS C O MM A NP (06h> 



The Set Parameters command allows the host to configure the 
controller to the attached drive and set specific parameters 
related to read and write operation. Some parameters specified by 
this command may also be established through the Mode Select 
command (15 H ). The controller will use the parameters contained 
in the last command issued (Set Parameters or Mode Select). 
Figure 6-7 shows the CDB for the Set Parameters command. 



Byte 
00 
01 
02 
03 
04 
05 



Bit 

76543210 
0 0 0 10 0 1 1 0 

Logical Unit # | Drive Manufacturer 

Number of Tracks 
Minimum Block Transfer 



0 0 0 0 0 |Extnd| | fmt 

0 0 0 0 0 0 0 0 

Figure 6-7. Set Parameters Command 



Drive Manufacturer (Bits 0-4, Byte 01): The characteristics of 
the capstan tachometer pulses from the tape drive can vary 
between drive manufacturers. The ACB-3530 can optimize up- 
to-speed performance when the drive manufacturer is 
specified. This field is set as follows: 



Code : 

0 
1 
2 
3 



Manufacturer: 

Cipher 5 1/4" 
Wangtec 5 1/4" 
Archive 5 1/4" 
300 mS QIC-36 Delay 



Number of Tracks (Byte 02): This byte specifies the maximum 
track number supported by the tape drive. The track count 
begins at 0 f therefore a nine track tape would be 
indicated with an 8 in the byte. This parameter replaces 
the number of tracks specified by the Mode Select command. 

Minimum Block Transfer (Byte 03): This byte specifies the 
minimum number of 5 12 byte blocks to be transferred to the 
controller at any one time. This parameter replaces both 
read and write thresholds specified by the Mode Select 
command. 
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In disconnecting systems, this value will determine when 
the ACB-3530 disconnects and reconnects. The controller 
will disconnect after transferring the specified number of 
bytes and reconnect when space is available for this 
number of blocks. This value is ignored on the last 
transfer of a command if it is less than the specified 
minimum. 

Extend Mode (Bit2 f Byte 04): This bit set enables the ACB-3530 
to perform extended write. In the extend mode the 
controller will continue streaming even is a buffer 
underrun occurs. The controller will continue to write the 
last block indefinately until another block of data is 
available in the buffer, the end of the physical track is 
reached or a new command is issued. This parameter sets 
the forced streaming value of the Mode Select command to 
FF. 

QIC Format (Bit 0, Byte 04): This bit specifies which QIC 

format the inserted cartridge utilizes. This bit set to 1 
indicates a QIC-11 format, reset to 0 indicates QIC-24. 
This parameter sets the Density Code of the Mode Select 
command to 04, for QIC-11, or 05, for QIC-24. 



This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following error 
codes could be returned from a Request Sense (03g) command: 



Sense Key : 
2 
5 

4 

6 



Error : 
Unit Not Ready 
Illegal Request 

Hardware Error 
Unit Attention 



Possible Cause: 

See Section 6.3.3 

Minimum block transfer 
exceeds buffer size. 

See Section 6.3.3 

See Section 6.3.3 
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6.6 READ COMMAND (08H> 



The Read command reads the specified blocks from the attached 
tape and transfers them to the requesting host. Figure 6-8 shows 
the CDB for the Read command. 



Bit 

Byte 7 6 5 4 3 2 1 0 



00 


1 o 


0 0 


1 0 1 


0 




0 


0 


01 


I Logical 


Unit # 


10 0 


0 




0 


1 1 


02 
03 
04 


1 (MSB) 
j - -+- 


-+- 
-+- 


-+- -+- 

Block Count 
-+- -+- 




-+- 

-+-' 




(LSB) 


05 


1 o 


0 0 


0 0 


0 




0 


0 



Figure 6-8. Read Command 



The reading will begin from the current tape position if the 
previous command left the tape at position for the read. This can 
be accomplished by a previous Read, Verify or Space command. 
Otherwise, the read must begin at BOT, indicated by the BOM bit 
in Unit Sense information (Section 6.3.2). This can be 
accomplished by a Rewind command. An attempt to execute a Read 
command when the above conditions are not met will result in a 
Check status and an Illegal Request (5) sense key. The read 
operation will terminate when all requested blocks are 
transferred, media of hardware errors occur or a file mark or 
recorded end of tape is encountered. 

The ACB-3530 will attempt to cache data on all tape reads. A 
multiple block Read command will cause the controller to fill the 
8K buffer with the next sequential blocks in anticipation of 
another read. This can be used to facilitate overlapped disk 
restore operations in non-disconnecting systems by executing a 
number of tape reads. 

In a disconnecting system, the ACB-35 30 will disconnect from the 
host when the buffer becomes empty, during the data transfer. 
The controller will reconnect when the the buffer has filled to a 
specified "threshold". This value is set by either the Set 
Parameters (06 H ) command, Minimum Number of Blocks byte or the 
Mode Select (15 command, Read Threshold byte. A value of 0 
in either of these bytes will default to 8 blocks, 4K of data. 
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A buffer overrun will occur if the host fails to empty the buffer 
fast enough. In the event of an overrun, the ACB-3530 will 
reposition the tape and wait for the buffer to become empty to 
resume reading. This sequence can take up to 2 seconds and can 
seriously degrade system performance. The host can monitor the 
frequency of data overruns through the Request Sense (03 H ) 
command, Under run Counter. 

The ACB-3530 will not transfer blocks containing errors to the 
host. Unrecoverable read errors will be reported to the host with 
a Check status and a Media Error (3) sense key. The suggested 
recovery is to space, 1 block, over the defective block and 
continue reading. 



6,5 .1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h) command: 

Sense Key: Error: Possible Cause: 

0 No Sense See Section 6.3.3 

2 Unit Not Ready See Section 6.3.3 

3 Media Error See Section 6.3.3 

4 Hardware Error See Section 6.3.3 

5 Illegal Request See Section 6.3.3 

Check that bit 0, byte 01 
is set. 

Previous command was a write 
type command. 

6 Unit Attention See Section 6.3.3 
8 Blank Check See scetion 6.3.3 



The Data Error Counter will be incremented each time the tape 
must be repositioned to reread a bad block. 

The Data Underrun Counter will be incremented each time the tape 
must be stopped to allow the host to empty the buffer. 
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W filTg COWARD (OA H ) 



The Write command will transfer the specified number of blocks 
from the host and sequentially write theM onto the attached tape. 
Figure 6-9 shows the CDB for the Write command. 



Bit 



Byte 


7 


6 


5 




4 




3 




2 


1 0 


00 


1 o 


0 


0 


1 


0 




1 




0 


1 0 


01 


I Logical 


Unit 


# 


1 


0 




0 




0 


c 


) 1 1 


02 
03 
04 


I (MSB) 
j - -+- 


-+- 




Block Count 
-+- -+- 




-+- 
-+ — 


-+- 

(LSB) 


05 


1 o 


0 


0 


-+- 


0 


-+- 


0 


-+- 


0 


( 

-+ — 


) 0 



Figure 6-9. Write Command 



The write operation is initiated with the controller 
transferring the first block of data into the buffer at which 
point the write begins. 

The writing will begin from the current tape position if the 
previous command left the tape at position for the write. This 
can be accomplished by a previous Write, Write File Mark or Space 
(to end of recorded media) command. Otherwise, the write must 
begin at BOT, indicated by the BOM bit in Unit Sense information 
(Section 6.3.2). This can be accomplished by a. Rewind or Erase 
command. Any attempt to execute a Write command without the above 
conditions met will result in a Check status and an Illegal 
Request (5) sense key. The write operation will terminate when 
all requested blocks are transferred, media or hardware errors 
occur or physical end of tape (Section 6.7.2) is encountered. 

The ACB-35 30 supports two modes of write operation; buff erred and 
non-buffered. The mode used is specified by the Mode Select (15 H ) 
command. The non-buffered mode will not present a completion 
status until all the blocks have been written to tape and 
verified. The buffered mode will present a completion status as 
the last block to be written has been transferred into the 
controller buffer. 

The controller buffer is configured for 15 blocks of buffered 
write data. 
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The buffered mode is invoked through the Mode Select (15 
command. It has been implemented on the ACB-35 30 to help 
facilitate streaming back-up in a non-disconnecting system. Once 
the host has filled the controller buffer and a completion status 
and message has been issued, the host has approximately 60-70mS 
to reissue the next sequential write operation. This time allows 
the host to obtain additional disk data. The next write will 
refill the buffer as space becomes available until the last block 
is transferred, when completion is again issued. If an error is 
encountered on writing buffered data for which a good completion 
status has already been issued, a Check status will be posted on 
the next tape access from the same host. See Section 6.7.3 for 
proper recovery. 

The non-buffered mode is generally used with a disconnecting 
system. The ACB-3530 will disconnect from the host when the 
buffer becomes full. The controller will reconnect when the 
buffer is emptied to a specified "threshold". This value is set 
through the Set Parameters (06 H ) command, Minimum Number of 
Blocks byte or the Mode Select (15) command, Write Threshold 
byte. The parameters contained within the last of these two 
issued will be used. A value of 0 in either of these bytes will 
result in a default of 8 blocks, 4K of data. The controller will 
report a completion status when the last block has been written 
to tape and verified. 



£,7,1 F ORCEP STREAMING 

The ACB-35 30 will attempt to keep the tape streaming on all write 
operations if a buffer underrun occurs in the forced streaming 
mode. A buffer underrun occurs during a buffered or non-buffered 
write operation when the host is not capable of transferring the 
blocks specified by the Write command into the controller buffer 
fast enough to supply the tape write. In the event of a buffer 
underrun the ACB-3530 will continue to stream the tape by 
continuously rewriting the last block. This forced streaming will 
continue for a maximum of the number of bl ocks specif ied in the 
Mode Select, Forced Streaming byte or until the end of the track, 
if the Set Parameters, Extend bit is set. The parameters in the 
last of these two commands issued will be used. Once the next 
block is available in the buffer, the controller will resume the 
write operation. 
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L*2*Z ENCOUNTERING MD £E MEDIA 



The host will be informed of the end of media when the early 
warning is detected by the ACB-3530. The current block written 
will be completed and a Check status will be posted with the EOM 
bit set in Unit Sense information and a Volume Overflow (D) sense 
key. The Block Count will contain the number of blocks, for the 
current and all previous commands, not written to tape. In the 
buffered mode, the Check status will be posted with the next 
access to the tape from the same host. Buffered data, completed 
but not yet written to tape can be recovered as detailed in 
Section 6.7.3, 



The tape will typically hold some additional number of blocks 
between early warning and the physical end of tape. If necessary, 
additional blocks or file marks can be written, one at a time, 
until the end of tape is reached. Multiple block writes will 
result in a Check status with an Illegal Request sense key. 
Single block writes will terminate with a Check status with the 
EOM bit set and a No Sense (0) sense key. The number of 
additional blocks written should not exceed 5. When a block write 
is interrupted by the physical EOM, a Check status will be posted 
with the EOM bit set and a Media Error (3) sense key. Since the 
interrupted block has not been verified it is not recoverable. 



6.7.1 WRITE ERRORS PURING EUFFERgp M OPE 

Recovering from errors encountered while writing data for which a 
good completion status has already been issued can be 
problematic. The ACB-3530 provides the host the capability to 
effectively recover from these errors. Upon encountering an error 
state, the controller will post a Check status. If write data 
from a write operation is currently being written into the 
buffer, the transfer will be interrupted with a Check status. If 
no subsequent command has been issued, a Check status will be 
posted with the next command from the same host. The related 
sense key will indicate the cause of the error state. Any 
attempts from another host to access the controller when an 
outstanding Check status is present, will result in a Busy status 
to that host. 

Assuming that a subsequent command has transferred data into the 
buffer and is interrupted by a Check status, the host can 
determine which blocks have been written to tape and recover the 
data in the buffer. 

To determine how many blocks have been written to the tape, the 
host should issue a Request Sense command to determine the Block 
Count. This value reports the number of blocks from the current 
and all previously buffered write commands that have not been 
written to tape. The Blocks to GO value (BYTE OF) reflects the 
same information. 
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When the host determines the residue block count of the previous 
buffered and current commands, a Recover Buffer Data (14 H ) 
command can be used to read the buffer data back into the host. 
This command will return all bytes left in the buffer from the 
current and all previous commands. The number of blocks specified 
in the command should equal the number of blocks in the buffer to 
assure all buffered data will be recovered, however more than one 
command can be used to recover all of the data. If the number of 
blocks transferred is less than the number specified, the ACB- 
3530 will present a Check status with the EOM bit set and a No 
Sense (0) sense key when the last block available in the buffer 
has been transferred. The Block Count in the Unit Sense 
information contains the difference between the number of blocks 
specified and number recovered. See description of Recover Buffer 
Data command, Section 6.12, for further details. 

Once the data has been recovered, a Write File Mark (10 R ) command 
is required to flush the buffer and resume normal write 
operations. 



6 .7, 4 MSP IA DEFECT HANDLING 

The ACB-35 30 checks each block on the tape for good CRC as it is 
being written. However, since the tape read head trails the write 
head by about 300 bytes, the CRC results for a given block (block 
N) are not known until after the next block write (N+l) has 
begun. The controller, therefore, assumes that the previous block 
will check correctly and begins writing the next block. A block 
will not be considered transferred to tape until a successful CRC 
check is completed. 

If the CRC check should fail, typically due to a media defect, 
the ACB-35 30 will complete the current block write (N+l) and then 
rewrite the previous block (N). This alternation between N and 
N+l will continue until a successful CRC check of block N is 
achieved or 16 unsuccessful writes have been attempted. If block 
N were the last block to be written, it would be repeated until a 
good CRC check is made. This results in the last block of each 
write to be written at least twice. After 16 unsuccessful 
attempts, a Check status will be posted with a Media Error (3) 
sense key. 



6.7.5 PO SS I PLP ERROR S T A TE S 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h) command: 



ACB-3530 Users Manual 



6-19 



400112-00A 



Sense Key** 
0 

2 
3 
5 



Error : 
No Sense 

Unit Not Ready 
Media Error 
Illegal Request 



Hardware Error 
Unit Attention 
Data Protect 

Volume Overflow 



Possible Cause: 

See Section 6.3.3 
Writing at EOM 

See Section 6.3.3 

See Section 6.3.3 

See Section 6.3.3 
Check that bit 0, byte 01 
is set. 

Previous command was a read 
type command. 

See Section 6.3.3 

See Section 6.3.3 

See Section 6.3.3 
Cartridge write protect. 

See Section 6.3.3 
Writing at EOM. 



The Data Error Counter will be incremented for each block 
that must be rewritten due to a CRC error. 

The Data Under run Counter will be incremented each time the tape 
must be stopped to allow the host to fill the buffer. 
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6.8 Write File Mark Command (10h) 



The Write File Mark command writes the specified number of file 
mark blocks to the tape, starting from the current tape position. 
File marks are used by the host for file management by 
partitioning areas of the tape with one or more sequential file 
marks. Figure 6-10 shows the CDB for the Write File Mark command. 



Bit 



Byte 


1 O 


R A "5 O 1 ft 

O 4 J z 1 U 


00 


1 0 0 


0|1 0 0 0 0 


01 


1 Logical Unit 


#10 0 0 0|0 


02 


I 0 0 


0 0 0 0 0 0 
0 0 0 0 0 0 


03 


1 0 0 


04 




File Mark Count 


05 


I 0 0 


0 0 0 0 0 0 




Figure 6 


-10. Write File Mark command 



The number of sequential file marks specified by the File Mark 
Count will be written to the tape. The file mark write will 
begin at the current tape position if the previous command left 
the tape at position for the write. This can be accomplished by a 
previous Write, Write File Mark or Space (to end of recorded 
media). Otherwise, the file mark write must begin at BOT, 
indicated by the BOM bit in Unit Sense information (Section 
6.3.2). This can be accomplished by a Rewind or Erase command. 
Any attempt to execute a Write File Mark command without the 
above conditions met will result in a Check status and an Illegal 
Request (5) sense key. The write operation will terminate when 
all requested file mark blocks are transferred, media or hardware 
errors occur or physical end of tape (Section 6.6.2) is 
encountered. 

A Fil e Mark Co unt of 0 will result in no file marks to be written 
however, the command will not be completed until all buffered, 
data from a previous Write command is transferred to tape. This 
may be used to insure that the last buffered write transfers to 
tape successfully. 

In a disconnecting system, the ACB-3530 will disconnect on 
file mark writes. The controller will reconnect to present 
command completion. 
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6^2. PQS S I P frg EEEQB STATE; S 



This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h^ command: 



Sense Key : 
0 

2 
3 
5 

4 

6 
7 



Error : 
No Sense 

Unit Not Ready 
Media Error 
Illegal Request 

Hardware Error 
Unit Attention 
Data Protect 

Volume Overflow 



Possible Cause: 

See Section 6.3.3 
Writing at EOM 

See Section 6.3.3 

See Section 6.3.3 

See Section 6.3.3 
Previous command was a read 
type command. 

See Section 6.3.3 

See Section 6.3.3 

See Section 6.3.3 
Cartridge write protected. 

See Section 6.3.3 
Writing at EOM. 



The Data Error Counter will be incremented for each file mark 
that must be rewritten due to a CRC error. 

The Data Underrun Counter will be incremented once when tape 
repositions after the last file mark is written. 
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SPA CE CQMM ANP (11h> 



The Space command is used to change the physical location of the 
tape in either the forward or reverse direction. This command is 
the only command that can be used to place the tape at position 
for both a read and write operation. Figure 6-11 shows the CDB 
for the Space command. 



Bit 



cy uc 


7 6 5 4 3 2 


1 0 


00 


10 0 0 11 0 0 


0 1 


01 


I Logical Unit # I 0 0 0 


I Search Code 


02 
03 
04 


I (MSB) 

| - -+- -+- -+- -+- 

I Space Count (N) 
1 - -+- 


-+- -+- 

-+- -+- 

(LSB) 


05 


10 0 0 0 0 0 


0 0 




Figure 6-11. Space command 



The type of tape positioning is specified by the Search Code. The 
direction and amount of tape motion is specified by the Space 
Count value, N. A positive N will result in a forward motion, a 
negative N will result in a reverse motion. Negative N values are 
represented in 2's complement notation. A zero value will result 
in no tape motion. 

The Space command allows the host to space across blocks, file 
marks or to the end of recorded media depending on the Search 
Code. The definition of each Search Code, 0 through 3, is shown 
in Table 6-3. 



Table 6-3. Space Search Codes 
Search Code Space Function 



0 


Space 


Blocks 


1 


Space 


File Marks 


2 


Space 


Sequential File Marks 


3 


Space 


to End of Recorded 



Media 



ACB-35 30 Users Manual 



6-23 



400112-00A 



Search Code = 0: Space blocks. Space over N blocks, either 
forward or reverse depending on the sign of N. The space 
will terminate when the specified number of blocks have 
been passed, with a good completion. If EOT, BOT, a file 
mark, or end of recorded media is encountered, a Check 
status will be posted with the appropriate sense bits set, 

A forward space will complete with the tape positioned at 
the end of the last block spaced or a file mark 
encountered, 

A reverse space will complete with the tape positioned at 
the beginning of the last block spaced. The ACB-35 30 does 
not search for file marks on a reverse space, any 
encountered will be treated as data blocks. Reverse spaces 
are limited to 128 blocks (Space Code = FFFF80 H ). 

Search Code = 1: Space File Marks. Space over N file marks in 
forward direction, toward EOT (a space in the reverse 
direction will result in tape motion to BOT, no f ile marks 
will be found). The space will terminate when the 
specified number of file marks have been spaced with a 
good completion. If EOT, BOT or end of recorded media is 
encountered, a Check status will be posted with the 
appropriate sense bits set. 

The space will complete with the tape positioned at the 
end of the last file mark spaced. 

Search Code = 2: Space Sequential File Marks. Spaces the tape 
forward until the next occurrence of N sequential file 
marks. Only positive counts are supported. The space will 
terminate when the specified number of sequential file 
marks have been encountered with a good completion. If 
EOT or end of recorded media is encountered, a Check 
status will be posted with the appropriate sense bits set. 

The space will complete with the tape positioned at the 
end of the last of the sequential file marks encountered. 

Search Code = 3: Space to End of Recorded Media. Spaces the 
tape to the end of the recorded media. The tape is left in 
the position to append data to the last block written. The 
Space Count field is ignored. 



A multiple block space operation will reread blocks with CRC 
errors until a good read is accomplished. Single block spaces 
will bypass CRC errors after 16 retries. This allows the host to 
space past bad blocks on prewritten tapes. 

On systems that support disconnection, the ACB-3530 will 
disconnect during lengthy tape motion and reconnect to present 
completion status. 
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6.9.2 PQ S SIPk B EBBQR STATES 



This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03r) command: 

Sense Key: Error: Possible Cause: 



0 


No Sense 


See 
EOM 


Section 6.3 
encountered 


.3 


2 


Unit Not Ready 


See 


Section 


6.3 


.3 


3 


Media Error 


See 


Section 


6.3 


.3 


5 


Illegal Request 


See 


Section 


6.3 


.3 


4 


Hardware Error 


See 


Section 


6.3 


.3 


6 


Unit Attention 


See 


Section 


6.3 


.3 


D 


Volume Overflow 


See 


Section 


6.3 


.3 



Spacing past BOT or EOT 



The Data Error Counter will be incremented each time the tape 
must be repositioned to re-read a bad block. 

The Data Underrun Counter will be incremented once when tape 
repositions after the last space. 
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6,10 I W PI HY CQHMANP (12 h) 



The Inquiry command passes information regarding the controller 
and attached device type to support self configuring systems. The 
CDB for the Inquiry command is shown in figure 6-12. 



Byte 
00 
01 
02 
03 
04 
05 



Bit 

7 6 5 4 3 2 1 0 
_ + + + + + + + 

0 0 0|1 0 0 1 0 
+ + + + + + + 

Logical Unit # | 0 0 0 0 0 
+ + + + + + + 

0 0 0 0 0 0 0 0 
+ + + + + + + 

0 0 0 0 0 0 0 0 

Number of Blocks 
+ + . — + + + + + 

00000000 
. — — + + + + + + + 

Figure 6-12. Inquiry Command 



The number of bytes allocated by the host to be returned as 
Inquiry data is specified in block 04. A value of zero will 
result in no data transferred. The total number of bytes 
available is 18 (decimal). Figure 6-13 shows the returned Inquiry 
data. 



The Inquiry data indicates: 

Device Type Code=01 

Device Type Qualifier=80 

ACB-3530 Firmware Rev. 

Number of Buffered Read Blocks 

Number of Buffered Write Blocks 

Adaptec Identifier 

Product Identifier 



Sequential Access 
Removable 

Firmware rev. in X. Y 
16 (decimal) 
15 (decimal) 
A-D-A-P-T-E-C in ASCII 
01 H indicates ACB-35 30 
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Bit 

Byte 76543210 



00 I 






Device oype Code (01) 






01 






Device Type Qualifier (80) 






02 I 


0 




0 0 0 0 0 0 




0 


03 1 


0 




0 0 0 0 0 0 




0 


04 






Number of Additional Bytes (OCr) 






05 


0 




0 0 0 0 0 0 




0 


06 






ACB-3530 Firmware Revision Level 






07 


0 




0 0 0 0 0 0 




0 


08 


1 


Number of Buffered Read Blocks (IOr) 






09 


Number of Buffered Write Blocks (OFr) 


OA 

• • 

• • 

10 


» 

l 


-+- 


Adaptec Inc. Identifier 


-+- 




11 






Product Identifier (OIr) 







Figure 6-13. Inquiry Data 



6- 10.1 PQ gg lPLE ERRQfi gTAT£g 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03g) command: 

Sense Key: Error: Possible Cause: 

4 Hardware Error See Section 6.3.3 

6 Unit Attention See Section 6.3.3 
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&JL1 ££EI£X CQHM ANP (13 H > 



The Verify command performs a CRC check on the number of blocks 
specified. The controller only performs a CRC check, no data is 
transferred to the host. Figure 6-14 shows the CDB for the 
Verify command. 



Bit 

Byte 7 6 5 4 3 2 1 0 



00 


1 o 


0 0 


11 0 0 1 


1 


01 


1 Logical 


Unit # 


10 0 C 


) | C 


1 1 1 


02 
03 
04 


1 (MSB) 
I - -+- 

1 - 


-+- 
-+- 


-+- -+- 

Block Count 
-+- -+- 


-+- 
-+- 


(LSB) 


05 


1 o 


0 0 


0 0 ( 


) 0 0 



Figure 6-14. Verify command 



The verify will begin from the current tape position if the 
previous command left the tape at position. This can be 
accomplished by a previous Read, Verify or Space command. 
Otherwise, the verify MUST begin at BOT, indicated by the BOM bit 
in Unit Sense information (Section 6.3.2). This can be 
accomplished by a Rewind command. An attempt to execute a Read 
command when the above conditions are not met will result in a 
Check status and an Illegal Request (5) sense key. The operation 
will terminate when all requested blocks are transferred, media 
of hardware errors occur or a file mark, recorded end of tape or 
physical end of tape is encountered. 



The command will verify the CRC on one or more blocks on the tape 
starting next block from the current position. The verification 
will terminate when the specified number of blocks have been 
verified, a file mark is encountered or EOT is encountered. If 
termination occurs before the block count is reached, the Unit 
Sense information will contain the remaining number of blocks. 

The controller will place the tape at the end of the last block 
verified or file mark encountered prior to completion. 
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fcUl.l POSSIBLE ER RO R STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5,7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h) command: 



Sense Key : 
0 
2 
3 
5 



4 
6 
7 
D 



Error : 
No Sense 

Unit Not Ready 
Media Error 
Illegal Request 



Hardware Error 
Unit Attention 
Data Protect 
Volume Overflow 



Possible Cause: 

See Section 6.3.3 

See Section 6.3.3 

See Section 6.3.3 

See Section 6.3.3 
Check that bit 0, byte 01 
is set. 

Previous command was a write 
type command. 

See Section 6.3.3 

See Section 6.3.3 

See Section 6.3.3 

See Section 6.3.3 
Verifying at EOM. 



The Data Error Counter will be incremented each time the tape 
must be repositioned to re-read a bad block. 

The Data Underrun Counter will be incremented once when tape 
repositions after the last space. 
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^12. RECOVER pqF Fgft D ATA COMM AN D (14 H > 



The Recover Buffer Data command is used to recover data left in 
the buffer as a result of an error occuring during a write 
operation. This command will return all buffer data from 
previously completed and current commands not yet written to tape 
and verified. Figure 6-15 shows the CDB for the Recover Buffer 
Data command. 







Bit 






Byte 


7 6 5 


4 3 


2 


1 0 


00 


10 0 0 


1 1 o 


1 


0 0 


01 


I Logical Unit # 


I 0 0 


0 | 


0 | 1 


02 
03 
04 


1 (MSB) 
j - -+- 

| - -+- -+- 


-+- -+- 

Block Count 
-+- 


-+- 
-+- 


-+- 

-+- 

(LSB) 


05 


10 0 0 


0 0 


0 


0 0 














Figure 6-15. 


Recover Buffer 


Data 


command 



The data will be transferred in the order that itwouldhave been 
written to tape. 

The Block Count can be set to the maximum buffer size to assure 
all buffered data is recovered. If a smaller count is used, 
multiple Recover Buffer Data commands can be used. If the Block 
Count exceeds the number of blocks available, a Check Status will 
be posted with a No Sense (0) sense key. The EOM bit will be set 
and the Unit Sense information Block Count will contain the 
difference between the number of blocks specified and transferred. 



LJ-2.1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03fj) command: 
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Sense Key: Error: Possible Cause: 

0 No Sense See Section 6.3.3 

Block Count exceeded data 
available (EOM bit set) 

2 Unit Not Ready See Section 6.3.3 

5 Illegal Request See Section 6.3.3 

Check that bit 0, byte 01 
is set. 

6 Unit Attention See Section 6.3.3 

Spacing past BOT or EOT 
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6.13 MODE SELECT COMMAND (15h> 

The Mode Select command is used by the host to configure the ACB- 
35 30 for the desired operational parameters. Some parameters can 
also be specified by the Set Parameters (06 H ) command. The 
overlapping values will be used from the* last command issued. 
Figure 6-16 shows the CDB for the Mode Select command. 



Bit 

Byte 765 43210 

| + + + + + + + 

00 | 0 0 0|1 0 1 0 1 

01 | Logical Unit # | 0 0 0 0 0 

02 | 0 0 0 0 0 0 0 0 
|- -+- -+- -+- -+- -+- -+- -+- 

03 1 0 0 0 0 0 0 0 0 
j + +- + -+ + + + 

04 | Number of Bytes 
| + + + + + + + 

05 |0 0 0 0 0 0 0 0 

Figure 6-16. Mode Select command 

The Number of Bytes specifies the number of bytes of 
configuration data to be sent to the controller. A minimum of 3 
bytes must be sent for any meaningful data, however less than 3 
is not an error state. It is recommended that the host provide 17 
bytes of data for full configuration. Figure 6-17 shows the Mode 
Select configuration data block. 

The Mode Select configuration data is defined as follows: 

Buffered Mode (bit 4, byte 02): This bit set invokes the 
buffered mode of write operation. Good completion status 
and message will be transferred by the controller when the 
last byte of write data is transferred into the controller 
buffer. An error encountered will be posted with the next 
command. (See Section 6.7, Write command, for additional 
details) 

Density Code (byte 04): This byte specifies the QIC format of 
the inserted tape. This can be overridden by the Set 
Parameters command. The density codes supported are: 



Density Code: 00 

04 
05 



QIC Format: 



QIC-24 
QIC-11 
QIC-24 



(default) 



Block Size (byte 0A-0B): These bytes specify the formatted 
block size on the tape. This must be set to 512 (02,00h)« 
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Byte 



Bit 
4 3 



oo i 


0 0 


0 0 0 0 


0 0 


01 1 


0 0 


0 0 0 0 


0 0 1 


02 | 


0 0 


0 |BufMd| 0 0 


0 0 


03 | 


Length 
+ 


of Extent Descriptor List 
" + + + + ~~ + ~ 

Extent Descriptor List 


(08 H ^ 


04 | 


+ 


Density Code 


+ 


05 | 


0 0 


0 0 0 0 


0 0 


06 I 


0 0 


0 0 0 0 


0 0 


07 I 


0 0 


0 0 0 0 


0 0 




0 0 


0 0 0 0 

SJ V/ \J \J 


0 0 


09 I 


0 0 


0 0 0 0 

- + ' + + + + " 


0 0 

+ 


OA | 
OB ! 


(MSB) 
-+- 

+ 


-+ Block Size - 
-+ + + + +- 
Operational Mode Parameters 


(LSB) 

+ 


OC 




Operational Code (04 H ) 




OD 




Number of Tracks 


+ 


OE 




Read Threshold 




OF 




Write Threshold 




10 




Forced Streaming Count 





Figure 6-17. Mode Select Configuration Data Block 
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The following fields define the operational mode of the ACB-3530: 

Number of Tracks (byte OD) : This byte configures the controller 
to the number of tracks on the inserted tape. Track counts 
supported are 04 or 09, a value of 00 in this byte will 
default the controller to the congf iguration jumper A-B 
(see Section 3.4). This can be overridden by the Set 
Parameters command Number of Tracks value. 

Read Threshold (byte 0E): This byte sets the buffer threshold 
for when the controller will reconnect on disconnecting 
read operations. The threshold value specifies the number 
of blocks that must be available to transfer to the host 
before reconnection. A read opertaion can buffer up to 16 
blocks. A zero in this field will default to 8. A value 
greater than 16 will default to 15. This can be overridden 
by the Set Parameters command Minimum Number of Blocks 
value. 

Write Threshold (byte OF): This byte sets the buffer threshold 
for when the controller will reconnect on disconnecting 
write operations. The threshold value specifies the number 
of blocks that must be free in the buffer before the 
controller will reconnect and request write data. A write 
operation can buffer up to 15 blocks. A zero in this field 
will default to 8 blocks. A value greater than 15 will 
default to 14. This can be overridden by the Set 
Parameters command Minimun Number of Blocks value. 

Forced Streaming Count (byte 10): This byte specifies the 



number of time the controller will rewrite the last block 
during a write operation in the event of a buffer 
underrun. A zero in this field will default to one block. 
Avalue of FF will result in a forced stream to the end of 
a track. An overriding Set Parameters command with the 
Extend bit set will set this field to FF. 



6.13.1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03 H ) command: 

Sense Key: Error: Possible Cause: 



2 



Unit Not Ready 



See Section 6.3.3 



6 



Unit Attention 



See Section 6.3.3 
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6.14 RESERVE UNIT COW HAND (16 H ) 



The Reserve Unit command will reserve the attached tape drive for 
the exclusive use of the requesting host. The reservation is 
released by a Release command (17 H ) or a power-on or SCSI reset. 
Figure 6-18 shows the CDB for the Reserve command. 



Bit 



Byte 


7 


6 


5 


-+- 


4 


-+- 


3 


-+- 


2 


-+- 


1 


0 


00 


1 o 


0 

i i 


0 


1 

-+- 


1 




0 


-+- 


1 




1 


0 


01 


I Logical Unit 


# 


1 


0 


-+- 

1 


0 




0 


-+- 


0 


0 






-+ +- 




-+- 








-+- 




-+- 






02 


1 o 


0 


0 




0 




0 




0 




0 


0 






-+ +- 








-+- 














03 


1 0 


0 


0 




0 




0 




0 




0 


0 




























04 


I 0 


0 


0 


-+- 


0 




0 


-+- 


0 


-+- 


0 


0 


05 


1 0 


0 


0 




0 




0 




0 




0 


0 










-+- 




-+- 




-+- 











Figure 6-18. Reserve Unit command 



An attempted access to a drive with an active reservation from 
another host will result in a Reservation Conflict status. 



6.14 . 1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03^) command: 

Sense Key: Error: Possible Cause: 

2 Unit Not Ready See Section 6.3.3 

6 Unit Attention See Section 6.3.3 



ACB-3530 Users Manual 



6-35 



400112-00A 



6.15 jBSLSASI J2HIT £QRt&£Q. (17 H ) 



The Release Unit command releases a drive reservation invoked by 
the same host. Figure 6-19 shows the CDB for the Release Unit 
command. 



Bit 

7 6 5 4 3 2 1 0 
+ + + + + + + | 

0 0 0 11 0 1 1 II 
+ + — - — + + + -+ + | 

ogical Unit #10 10 0 0 0 | 
- — + + + + + + + | 

000000001 
+ + + + + + + I 

000000001 
+ + + + + + + | 

0 0 0 0 0 0 0 0 | 
+ + + + + + + 1 

000000001 
+ .-+ + + + + + 1 

Figure 6-19. Release Unit Command 

A Release Unit command to a drive that has an active reservation 
from another host will result in a Reservation Conflict status. 



POSSIPfrE EfiRQR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h^ command: 

Sense Key: Error: Possible Cause: 

2 Unit Not Ready See Section 6.3.3 

6 Unit Attention See Section 6.3.3 



Byte 
00 
01 
02 
03 
04 
05 
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6.16 ERASE CQMMANP (19h> 



The Erase command will erase the entire tape inserted. The drive 
erase head covers the entire tape, all tracks will be erased in 
one forward motion from the beginning of track 0 to the physical 
end of track 0. Figure 6-20 shows the CDB for the Erase command. 



Bit 



Byte 


7 6 5 


4 3 2 1 0 


00 


10 0 0| 


110 0 1 


01 


1 Logical Unit # I 


0 0 0 0|1 


02 


10 0 0 


0 0 0 0 0 


03 


10 0 0 

j + + +- 


0 0 0 0 0 


04 


10 0 0 


0 0 0 0 0 


05 


10 0 0 


0 0 0 0 0 



Figure 6-20. Erase Command 



The erase operation must begin at BOT. An attempt to erase a tape 
not at BOT will result in a Check status with an Invalid Request 
sense key. 

If the host has indicated the ability to disconnect (through the 
Identify message), the ACB-3530 will disconnect during the erase 
process and reconnect to present ending status. 



6.16.1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03^) command: 
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Sense Key: Error: Possible Cause: 

2 Unit Not Ready See Section 6.3.3 

4 Hardware Error See Section 6.3.3 

5 Illegal Request See Section 6.3.3 

Check that bit 0 r byte 

is set. 
Tape not at BOT 

6 Unit Attention See Section 6.3.3 

7 Data Protect See Section 6.3.3 
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6,17 mq pb sens e; CQMMANP (1AH 5 



The Mode Sense command will return the configuration parameters 
set by the Mode Select or Set Parameters command to the host. 
Figure 6-19 shows the CDB for the Mode Sense command. 



Byte 
00 
01 
02 
03 
04 
05 



Bit 



76543210 
0 0 0|1 1 0 1 0 

Logical Unit # I 0 0 0 0 0 



00000000 
00000000 

Number of Bytes 
0 0 0 0 0 0 0 0 

Figure 6-21. Mode Sense Command 



The number of bytes specifies how many bytes will be returned by 
the controller. The format data returned is the same as the Mode 
Select Configuration Data (see Section 6.13, Mode Select 
command). The entire configuration data length is 17 blocks. If 
a Set Parameters command has been issued last, the overlapping 
parameters will reflect the Set Parameters values in the Mode 
Select value convention. 



£U7,1 POSSIBLE E RfiQ R STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03 H ) command: 



Sense Key : 
2 
4 
6 



Error : 
Unit Not Ready 
Hardware Error 
Unit Attention 



Possible Cause: 
See Section 6.3.3 
See Section 6.3.3 
See Section 6.3.3 
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6,18 IiOAP/UNIiOAP WIT COMM ANP (1b h) 



The Load/Unload command is used by the host to prepare the tape 
for insertion or removal. This command allows the host to place 
the tape at BOT or EOT and to retension the tape. Figure 6-20 
shows the CDB for the Load/Unload command. 



Bit 



Byte 


7 6 


5 4 3 2 1 0 


00 


j + +- 

i 0 0 


+ + + + + 

0|1 1 0 1 0 


01 


1 + +- 

I Logical Unit 


+ + + + + 

#10 0 0 0 llmmed 


02 


10 0 


0 0 0 0 0 0 


03 


I 0 0 


0 0 0 0 0 0 


04 


I 0 0 


0 0 0 0 |ReTen| Load 


05 


I EOT | 0 
j + 


0 0 0 0 0 0 



Figure 6-22. Load/Unload Command 



The specific function of the Load/Unload command is determined by 
the Retension, Load and EOT bits. The definition of each function 
is as follows: 

Retension (bit l f byte 04): This bit set will cause the 
controller to retension the tape prior to any load or 
unload function. A tape retension consists of a rewind to 
BOT, motion to EOT and a rewind back to BOT. This is 
recommended prior to writing to a new or stored tape. 

Load = 1 (bit 0, byte 04): This bit set indicates a load 
function. To properly initialize to inserted drives 
(without power-on reset), this function will cause the 
controller to position the tape at BOT and determine tape 
length for proper write current. 

Load = 0 (bit 0, byte 04): This bit and the Retension bit 
cleared indicates an unload function. This function will 
cause the controller to position the tape at BOT or EOT 
(see EOT bit below) 

EOT = 1 (bit 7 byte 05): This bit in an unload operation will 
result in the tape being positioned at EOT. This bit 
cleared will position the tape at BOT. 
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If the host does not support disconnect and the Immediate bit 
(byte 01, bit 00) is not set, this command will return a 
completion status at the end of the load/unload process. If the 
Immediate bit is set, the ACB-3530 will return good completion 
status at the initiation of load/unload. During the operation, 
the controller will return a Busy status in response all 
commands. 

If the host has indicated the ability to disconnect (through the 
Identify message), the ACB-3530 will disconnect during tape 
motion and reconnect to present ending status. 



6,19*1 PQ SS I PkE PRRQ R ST ATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h) command: 

Sense Key: Error: Possible Cause: 



2 



Unit Not Ready 



See Section 6.3.3 



4 



Hardware Error 



See Section 6.3.3 



6 



Unit Attention 



See Section 6.3.3 
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